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猿 媛 之 家 成 立 于 2015 年 8 月 ， 是 一 
家 致力 于 研究 程序 员 人 人生 规 划 、 程 序 员 
技能 与 培训 、 程 序 员 就 业 与 发 展 的 机 
构 。 虽 在 为 广大 求职 者 提供 求职 一 站 式 

， 为 求职 者 量体裁衣 ， 打 造 一 套 适 
合 目 己 的 求职 解决 方案 。 机 构成 员 均 毕 
业 于 国内 “985”“211” 高 校 的 计算 机 
相关 专业 ， 就 职 于 BAT 等 顶尖 IT 企业 。 

机 构 宗旨 是 “服务 大 众 、 分 层 对 
待 、 整 体 提高 、 打 造 精品 ”， 目 标 是 
“让 天 下 没有 找 不 到 工作 的 程序 员 ”。 
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e 微 信 订 阅 号 : 猿 媛 之 家 

e 网 站 : http:/www.yuanyuanzhijia.com 

e QQ 群 : 496588733 

e 官方 QQ: 3258614592 

e 官方 微 博 : http://weibo.com/yuanyuanzhijia 
e 官方 邮箱 : yuancoder@foxmail.com 
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本 书 针对 当前 各 大 IT 企业 面试 笔试 中 的 特性 与 侧重 点 ， 精 心 挑选 了 近 
3 年 来 18 家 顶级 IT 企业 的 面试 笔试 真题 ， 这 些 企业 涉及 业务 包括 系统 软 
件 、 搜 索引 擎 、 电 子 商务 、 手 机 APP 以 及 安全 软件 等 ， 非 常 具有 代表 性 与 
参考 性 。 同 时 ， 本 书 对 这 些 题 目 进行 了 应 丁 解 牛 式 的 分 析 与 讲解 ， 针 对 试 
题 中 涉及 的 部 分 重 难点 问题 ， 进 行 了 适当 地 扩展 与 延伸 ， 力 求 对 知识 点 的 
讲解 清晰 而 不 紊乱 ， 全 面 而 不 咖 嗪 ， 使 读者 能 够 通过 本 书 不 仅 获取 到 求职 
的 知识 ， 同 时 更 有 针对 性 地 进行 求职 准备 ， 最 终 能 够 收获 一 份 满意 的 
Mf 
本 书 是 一 本 计算 机 相关 专业 毕业 生 面 试 、 笔 试 的 求职 用 书 ， 同 时 也 适 
期 望 在 计算 机 软 、 硬 件 行业 大 显 身手 的 计算 机 爱好 者 阅读 。 
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程序 员 求 职 始终 是 
程序 员 代 码 面 试 指南 》( 左 程 云 著 )、《 剑 指 offer》( 何 海 涛 车 )、《 程 序 员 面 试 笔试 宝典 》( 何 


x 
前 证 
当前 社会 的 一 个 热点 ， 而 市 面 上 有 很 多 关于 程序 员 求 职 的 书籍 ， 例 如 


吴 编 车)、《Java 程序 员 面 试 笔试 宝典 》( 何 吴 编 著 )、《 编 程 之 美 》( 《编程 之 美 》 小 组 著 ) 及 
《编程 珠 丽 》(Jon Bentley 著 ) 等 。 这 些 图 书 都 是 针对 基础 知识 的 讲解 ， 各 有 侧重 点 ， 而 且 在 
市 场 上 反映 良好 。 但 是 ， 我 们 发 现 ， 当 前 市 面 上 还 没有 一 本 专门 针对 C/C++ 程序 员 、Java 程 
序 员 的 面试 笔试 真题 的 分 析 与 讲解 。 很 多 读者 朋友 们 反映 ， 他 们 经 过 了 精心 的 准备 以 后 ， 感 


觉 自己 什么 知识 都 会 了 ， 但 又 感觉 自己 什么 都 不 会 ， 不 知道 自己 是 否 真 的 能 够 在 程序 员 面 试 


笔试 中 得 心 应 手 ， 心 号 


一 点 底 都 没有 ， 偶 尔 会 搜索 一 下 网 上 一 些 IT 企业 的 面试 笔试 真题 ， 但 
这 些 题 大 都 七 零 八 竣 ， 坚 无 系统 性 可 膏 ， 而 且 绝 大 多 数 都 是 一 些 网 友 自 己 做 的 ， 管 案 人 简单， 


准确 性 不 高 ， 也 没有 
否 正 确 ， 完 全 是 徒劳 


Ey 


详细 的 讲解 ， 这 就 导致 读者 做 完了 这 些 真 题 ， 根 本 就 不 知道 自己 做 得 是 


。 如 果 下 一 次 这 个 题目 再 次 被 考察 ， 自 己 还 是 不 会 。 更 有 甚 者， 网 上 的 
答案 很 有 可 能 是 错误 的 ， 此 时 还 会 误导 读者 。 


针对 这 种 情况 ,我们 团队 经 过 精心 准备 ， 细 致 挑选 了 18 套 顶 级 企业 的 笔试 真题 ， 将 其 汇 


集成 册 ， 形 成 了 这 本 《Java 程序 员 面 试 笔试 真题 库 》。 本 书 汇集 了 近 三 年 来 各 大 IT 顶级 知名 
企业 的 笔试 真题 ， 编 者 从 数 百 份 真题 中 挑选 的 这 18 套 真题 非常 具有 代表 性 ， 有 具体 而 言 ， 主 要 


第 一 ， 考 察 率 高 


例如 语言 基础 、 链 表 、 


; 本 书 中 所 选 真题 绝 非 泛 泛 之 非 ， 其 内 容 均 是 程序 员 面 试 笔试 常 考点 ， 
算法 及 海量 数据 处 理 等 。 


第 二 ， 行业 代 表 性 强 ， 本 书 


代表 了 行业 的 高 水 准 


第 三 ， 答 案 详 尽 


FP 所 选 真题 全 部 来 自 于 顶级 知名 企业 ， 它 们 是 行业 的 风向 标 ， 


， 其 中 绝 大 多 数 真 题 因 为 题目 难 易 适 中 ， 而 且 具 有 非常 好 的 区 分 度 ， 通 
常会 被 众多 小 企业 全 盘 照 搬 ， 具 有 代表 性 。 


; 本 书 对 每 


道 题 目 都 有 非常 详细 的 解答 ， 应 丁 解 牛 ， 不 只 是 告诉 读者 


答案 ， 还 提供 了 详细 的 解答 过 程 。 授 之 以 鱼 的 同时 还 授 之 以 渔 ， 不 仅 告诉 答案 ， 还 告诉 读者 


同类 型 题目 以 后 再 遇 到 了 该 如 何 解答 。 读 者 在 学 完了 基础 知识 以 后 ， 可 以 抽 上 一 两 个 小 时 的 


时 间 来 完成 本 书 中 的 习题 ， 找 出 自 
由 于 图 书 的 篇 幅 所 限 ， 我 们 无 法 将 所 有 程序 员 面 试 笔 试 的 真题 内 容 都 写 在 书稿 中 ， 鉴 于 


己 的 知识 盲区 ， 查 漏 补缺 ， 为 知识 盲区 加 油 、 补 课 。 


此 ， 猿 姐 之 家 在 官方 网 站 (www.yuanyuanba.com) 上 提供 了 一 个 读者 交流 平台 ， 读 者 朋友 们 
可 以 在 该 网 站 上 上 传 各 类 面试 笔试 真题 ， 也 可 以 查找 到 自己 所 需要 的 知识 ， 同 时 ， 读 者 朋友 


们 也 可 以 向 本 平台 提 


供 当前 最 新 、 


最 热门 的 程序 员 面 试 笔试 题 、 面 试 技巧 以 及 程序 员 生 活 等 


相关 材料 。 除 此 以 外 ， 我 们 还 建立 了 公众 号 : 猿 媛 之 家 ， 作 为 对 外 消息 的 发 布 平台 ， 以 最 大 


限度 地 满足 读者 需要 。 欢 迎 读 者 关注 探讨 新 技术 。 


本 书 主要 针对 Java 用 户 ， 男 


外 还 有 专门 针对 C/C++ 用 户 的 图 书 ， 同 期 出 版 发 行 。 有 需要 


Java 程序 员 面 试 笔试 真题 库 


的 读者 可 以 在 各 大 电 商 网 站 或 实体 书店 购买 。 


感谢 在 成 长 道路 上 帮助 我 们 的 人 ， 他 们 是 父母 、 亲 人 、 同 事 、 朋 友和 同学 ， 无 论 我 们 中 


到 了 多 大 的 挫折 与 困难 ， 他 们 都 对 我 们 不 离 不 充 ， 一 如 既往 地 支持 与 帮助 我 们 ， 使 我 们 能 
开 开 心心 地 度 过 每 一 天 。 在 此 对 以 上 所 有 人 和 致 以 最 衷心 的 感谢 。 

所 有 的 成 长 和 伟大 ， 如 同 中 药 和 老 火 汤 ， 
都 是 逐 字 逐 名 琢磨 出 来 的 。 在 技术 的 海洋 里 ， 


识 传播 者 的 角 
现 自己 的 人 生理 想 与 抱负 。 


都 是 一 个 时 辰 一 个 时 辰 熬 出 来 的 ， 所 有 的 好 书 ， 
我 们 不 是 创造 者 ， 但 我 们 更 愿意 去 当 好 一 名 知 


色 ， 让 更 多 的 求职 者 能 够 通过 本 书 的 系统 学 习 ， 找 到 一 份 自己 满意 的 工作 ， 实 


每 个 人 的 人 生 都 是 一 场 戏剧 ， 而 每 个 人 都 要 成 为 自己 戏剧 的 主角 ， 不 应 该 沦 为 别人 戏剧 
。 所 以 ， 我 建议 所 有 的 求职 者 在 求职 的 道路 上 ， 无 论 遇 到 了 多 大 的 困难 ， 遭 遇 了 多 大 
的 挫折 ， 都 不 要 轻 言 放弃 ， 你 们 的 母校 可 能 不 是 “985”“211” 你 们 的 学 历 可 能 不 是 本 科 生 、 
研究 生 ， 你 们 的 专业 可 能 也 不 与 计算 机 相关 ， 


的 配角 


一 名 程序 员 ， 以 我 们 条 


可 以 进去 的 。 请 记 住 : 


于 编者 水 平 有 限 ， 书 中 不 足 之 处 在 所 


上 导 过 的 成 二 上 万 的 求职 者 经 验 而 言 ， 百 分 之 九 十 以 上 的 企业 是 你 完全 
在 这 个 世界 上 ， 没 有 人 可 以 让 你 仰视 ， 除 非 你 自己 跪 着 。 


但 这 些 都 不 要 紧 ， 只 要 你 认真 努力 ， 立 志 成 为 


免 ， 还 望 读 者 见谅 。 读 者 如 果 发 现 问题 或 有 此 


方面 的 困惑 ， 可 以 通过 邮箱 yuancoder@foxmail.com 联 系 我 们 。 
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面试 笔试 经 验 技巧 局 


想 找 到 一 份 程序 员 的 工作 ， 一 点 技术 都 没有 显然 是 不 行 的 ， 但 是 ， 只 有 技术 
也 是 不 够 的 。 面试 笔试 经 验 技巧 0 面试 笔试 中 遇 到 的 13 个 常见 问 
题 进行 深度 解析 ， 并 且 结 合 实际 情景 ， 给 出 了 一 个 较为 合理 的 参考 答案 以 供 读者 
学 习 与 应 用 ， 掌 握 这 13 个 问题 的 解答 精髓 ， 对 于 求职 者 大 有 神 益 。 


Java 程序 员 面 试 笔试 真题 库 


如 何 巧妙 地 回答 面试 官 的 问题 ? 


所 谓 “ 来 者 不 善 ， 善 者 不 来 ” 程序 员 面 试 中 ， 求 职 者 不 可 避免 地 需要 回答 面试 官 各 种 酉 
钻 、 犀 利 的 问题 ， 回 答 面 试 官 的 问题 千 万 不 能 简单 地 回答 “是 ”或 者 “不 是 ”， 而 应 该 具体 分 


析 “ 是 ”或 者 “不 是 ”的 理 


回答 面试 官 的 问题 是 一 门 很 深入 的 学 问 。 那 么 ， 面 对 面试 官 提出 的 各 类 问题 ， 


条 理 清晰 地 回答 呢 ? 如 何 才能 让 自己 的 回答 不 至 于 撞 上 检 
令 面试 官 满意 呢 ? 
谈 训 


如 何 才 能 


口 呢 ?如何 才 能 让 自己 的 回答 结果 


是 一 种 艺术 ， 回 答 问 题 也 是 一 种 艺术 ， 同 样 的 话 ， 不 同 的 回答 方式 ， 往 往 也 会 产生 


出 不 同 的 效果 ， 甚 至 是 截然 不 同 的 效果 。 在 此 ， 编 者 提出 以 下 几 点 建议 ， 供 读者 参考 。 首 先 


回答 问题 务必 谦虚 谨慎 。 既 不 能 让 面试 官 觉得 自己 很 自 乍 


， 唯 唯 诺 诡 ， 也 不 能 让 国 


Dye w= 
试 官 觉得 


自己 清高 自负 ， 而 应 该 通过 问题 的 回答 表现 出 自己 自信 从 容 、 不 捍 不 亢 的 一 面 。 例 如 ， 当 面 


试 官 提出 “你 在 项 目 中 起 到 了 什么 作用 ”的 问题 时 ， 如 果 求 职 者 回答 : 我 完成 了 团队 中 最 难 
回答 : 我 完成 了 文件 系统 的 构建 工 
内 容 ， 因 为 它 儿 乎 无 法 重用 以 前 的 


的 工作 ， 此 时 就 会 给 面试 官 一 种 居 功 自傲 的 感觉 ， 而 如 果 
作 ， 这 个 工作 被 认为 是 整个 项 目 中 最 具有 挑战 性 的 一 部 分 


框架 ， 需 要 重新 设计 。 这 种 回答 不 仅 不 傲慢 ， 反 而 有 理 有 据 ， 更 能 打动 面试 官 。 
其 次 ， 回 答 面 试 官 的 问题 时 ， 不 要 什么 都 说 ， 要 适当 地 留 有 蕊 念 。 人 一 般 都 有 猎奇 的 心 
更 有 兴趣 、 更 加 偏爱 ， 也 更 加 记忆 


理 ， 面 试 官 自然 也 不 例外 ， 而 且 ， 人 们 往往 对 好 奇 的 事情 


深刻 。 所 以 ， 在 回答 面试 官 问题 时 ， 切 记 说 关键 点 而 非 纪 


况 ， 都 可 以 将 时 间 复 杂 度 从 OO 降低 到 O(log n)， 如 果 您 
的 细节 。 


节 ， 说 重点 而 非 和 盘 托 出 ， 通 过 关 


键 点 ， 吸 引 面 试 官 的 注意 力 ， 等 待 他 们 继续 “ 创 根 问 底 ”。 例如 ， 当 面试 官 对 你 的 简历 中 一 个 
算法 问题 有 兴趣 ， 和 希望 了 解 时 ， 可 以 如 下 回答 : 我 设计 的 这 种 查找 算法 ， 对 于 80% 以 上 的 情 
有 兴趣 ， 我 可 以 详细 给 您 分 析 有 具体 


最 后 ， 回 答 问题 要 条 理 清晰 、 简 单 明 了 ， 最 好 使 用 “三 段 式 ”方式 。 所 谓 “ 三 段 式 ” 有 


点 类 似 于 中 学 作文 中 的 写作 风格 ， 包 括 “ 场 景 /任务 ”“ 行 动 ” 和 “ 


结果 ”三 部 分 内 容 。 以 面 


试 官 提 的 问题 “你 在 团队 建设 中 ， 遇 到 的 最 大 挑战 是 什么 ”为 例 ， 第 一 步 ， 分 析 场 景 /任务 : 
在 我 参与 的 一 个 ERP 项 目 中 ， 我 们 团队 一 共 四 个 人 ， 除 了 我 以 外 的 其 他 三 个 人 中 ， 两 个 人 


能 力 很 给 力 ， 人 也 比较 好 相处 ， 但 有 一 个 人 却 不 太 好 相处 ， 每 次 我 


他 都 不 太 爱 说 话 ， 也 很 少 发 言 ， 分 配给 他 的 任务 也 很 难 完 成 。 第 二 步 ， 分 析 行 动 : 


团队 的 综合 实力 , 我 决定 找 个 时 间 和 他 好 好 单独 谈 一 谈 。 


] 小 组 讨论 问题 的 时 候 ， 


为 了 提高 


于 是 我 利用 周末 时 间 , 约 他 一 起 吃 


饭 ， 吃 饭 的 时 候 , 顺便 讨论 了 一 下 我 们 的 项 目 , 我 询问 了 一 些 项 目 中 他 过 到 的 问题 ， 


通过 他 


的 回答 ,我 发 现 他 并 不 懒 ， 也 不 糊涂 ， 只 是 对 项 目 不 太 了 解 ， 缺乏 经 验 ， 缺乏 自信 和 而已， 所 
以 越 来 越 扳 立 ， 越 来 越 不 愿意 讨论 问题 。 为 了 解决 这 个 问题 ， 我 尝试 着 把 问题 细 化 到 他 可 以 


完成 的 程度 ， 从 而 建立 起 他 的 自信 心 。 第 三 步 ， 分 析 结 果 : 


他 是 小 组 中 水 平 最 弱 的 人 , 但 是 
慢 慢 地 , 他 的 技术 变 得 越 来 越 厉害 了 ， 也 能 够 按时 完成 安排 给 他 的 工作 了 ， 人 也 越 来 越 自 
了 , 也 越 来 越 喜 欢 参 与 我 们 的 讨论 , 并 发 表 自 己 的 看 法 , 我 们 也 都 愿意 与 他 一 起 合作 了 。“ 
段 式 ” 回 答 的 一 个 最 明显 的 好 处 就 是 条 理 清晰 ， 既 有 描述 ， 也 有 结果 ， 有 根 有 据 ， 让 面试 


或 |l| 开 


一 目 了 然 。 
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回答 问题 的 技巧 ， 是 一 门 大 的 学 问 。 求 职 者 完全 可 以 在 平时 的 生活 中 加 以 练习 ， 提 高 自 


己 与 人 沟通 的 技能 ， 等 到 面试 时 ， 自 然 就 得 心 应 手 了 。 


如 何 回答 技术 性 的 问题 ? 


程序 员 面 试 中 ， 面 试 官 会 经 常 询 问 一 些 技 术 性 的 问题 ， 有 的 问题 可 能 比较 简单 ， 都 是 历 


年 的 笔试 面试 真题 ， 求 职 者 在 平时 的 复习 中 会 经 常 遇 到 ， 应 对 自然 不 在 话 下 。 但 有 的 题目 可 
能 比较 难 , 来 源 于 Google、Microsoft 等 大 企业 的 题库 或 是 企业 自己 为 了 招聘 需要 设计 的 题库 ， 
求职 者 可 能 从 来 没 见 过 或 者 从 来 都 不 能 完整 地 、 独 立地 想到 解决 方案 ， 而 这 些 题目 往往 又 是 


企业 比较 关注 的 。 
如 何 能 够 回答 好 这 些 技术 性 的 问题 呢 ? 编者 建议 : 


会 做 的 一 定 要 拿 满分 ， 不 会 做 的 一 定 


要 拿 部 分 分 。 即 对 于 简单 的 题目 ， 求 职 者 要 努力 做 到 完全 正确 ， 毕 竞 这 些 题目 ， 只 要 复习 得 
当 ， 完 全 回答 正确 一 点 问题 都 没有 编者 认识 的 一 个 朋友 据说 把 《编程 之 美 》》《 编 程 珠 丽 》、 


《程序 员 面 试 笔试 宝典 》 上 面 的 技术 性 题目 与 答案 全 都 


背 得 深 瓜 烂熟 了 ， 后 来 找 工作 简直 成 了 


“offer 杀 器 ”完全 就 是 一 个 Bug, 无 解 了 ); 对 于 难度 比较 大 的 题目 ， 不 要 惊慌 ， 也 不 要 害怕 ， 


即使 无 法 完全 做 出 来 ， 也 要 努力 思考 问题 ， 哪 怕 是 半成品 也 要 写 出 来 ， 至 少 要 把 自己 的 思路 
表达 给 面试 官 ， 让 面试 官 知道 你 的 想法 ， 而 不 是 完全 回答 不 会 或 者 放弃 ， 因 为 面试 官 很 多 时 


候 除 了 关注 你 的 独立 思考 问题 的 能 力 以 外 ， 还 会 关注 你 技术 能 力 的 可 塑性 ， 观 察 求职 者 是 否 
能 够 在 别人 的 引导 下 去 正确 地 解决 问题 ， 所 以 ， 对 于 你 不 会 的 问题 ， 他 们 很 有 可 能 会 循序 渐 
进 地 启发 你 去 思考 ， 通 过 这 个 过 程 ， 让 他 们 更 加 了 解 你 。 

一 般 而 言 ， 在 回答 技术 性 问题 时 ， 求 职 者 大 可 不 必 胆 战 心 惊 ， 除 非 是 没 学 过 的 新 知识 ， 


人 否则， 一般 都 可 以 采用 以 下 六 个 步骤 来 分 析 解 决 。 
(1) 勇于 提问 


面试 官 提出 的 问题 ， 有 时 候 可 能 过 于 抽象 ， 让 求职 者 不 知 所 措 ， 或 者 无 从 下 手 ， 所 以 ， 
对 于 面试 中 的 疑惑 ， 求 职 者 要 勇敢 地 提出 来 ， 多 向 面试 官 提问 ， 把 不 明确 或 二 义 性 的 情况 都 


问 清楚 。 不 用 担心 你 的 问题 会 让 面试 官 烦恼 ， 影 响 你 的 面试 成 绩 ， 相 反 还 对 面试 结果 产生 积 


极 影响 : 一 方面 ,提问 可 以 让 面试 官 知 道 你 在 思考 ， 也 可 以 给 面试 官 一 个 心思 绩 密 的 好 印象 ; 


男 一 方面 ， 方 便 后 续 自 己 对 问题 的 解答 。 


例如 ， 面 试 官 提出 一 个 问题 ， 设 计 一 个 高 效 的 排序 算法 。 求 职 者 可 能 丈 二 和 尚 摸 不 到 头 


脑 ， 排 序 对 象 是 链表 还 是 数组 ? 数据 类 型 是 整 型 、 浮 点 型 、 字 符 型 还 是 结构 体 类 型 ? 数据 基 


本 有 序 还 是 杂乱 无 序 ? 数据 量 有 多 大 ，1000 以 内 还 是 百 万 以 上 个 数 ? 此 时 ， 求 职 者 大 可 以 将 


自己 的 疑问 提出 来 ， 问 题 清楚 了 ， 解 决 方案 也 自然 就 
(2) 高 效 设计 


来 了 。 


对 于 技术 性 问题 ， 如 何 才能 打动 面试 官 ? 完成 基本 功能 是 必须 的 ， 仅 此 而 已 吗 ? 显然 不 


是 ， 完 成 基本 功能 项 多 只 能 算 及 格 水 平 ， 要 想 达 到 优秀 水 平 ， 至 少 还 应 该 考虑 更 多 的 内 容 ， 
以 排序 算法 为 例 : 时 间 是 否 高 效 ? 空间 是 否 高 效 ? 数据 量 不 大 时 也 许 没 有 问题 ， 如 果 是 海量 


数据 昵 ? 是 否 考虑 了 相关 环节 ， 例 如 数据 的 “增删 改 查 ”? 是 否 考虑 了 代码 的 可 扩展 性 、 安 
全 性 、 完 整 性 以 及 和 鲁 棒 性 ?如果 是 网 站 设计 ， 是 否 考虑 了 大 规模 数据 访问 的 情况 ? 是 否 需要 


Java 程序 员 


考虑 分 布 式 系统 架构 ? 是 否 考虑 了 开源 框架 的 使 用 


本 试 笔 试 真题 库 


(3) 伪 代 人 码 先行 


有 时 候 实际 代码 会 比较 复杂 ， 上 手 就 写 很 有 可 


能 会 漏洞 百出 、 


条 理 混 乱 ， 所 以 ， 求 职 


可 以 首先 征求 面试 官 的 同意 ， 在 编写 实际 代码 前 ， 写 一 个 伪 代 码 或 者 画 好 流程 图 ， 这 样 做 往 
往 会 让 思路 更 加 清晰 明了 。 


切记 在 写 伪 代码 前 要 告诉 面试 官 ， 他 们 很 有 可 能 对 你 产生 误解 ， 认 为 你 上 


只 会 纸上谈兵 ， 


实际 编码 能 力 却 不 行 。 只 有 征 得 了 他 们 的 允许 ， 方 可 先 写 伪 代 码 。 


(4) 控制 节奏 

如 果 是 算法 设计 题 ， 
右 。 完 成 得 太 慢 ， 会 给 面试 官 留 下 能 力 不 行 的 印象 ， 
确 ， 也 会 给 面试 官 留 下 毛 手 毛 脚 的 印象 ， 速 度 快 当然 
度 快 根本 不 会 给 面试 加 分 。 所 以 ， 编 者 建议 ， 回 
如 果实 在 是 完成 得 比较 快 ， 也 不 要 和 急 了 


面试 官 都 会 给 求职 者 一 个 时 间 限 制 用 以 完成 设计 ， 一 般 为 20min 左 


但 完成 得 太 快 ， 如 果 不 能 保证 百 分 百 正 


是 好 事情 ， 但 只 有 速度 ， 没 有 质量 ， 速 


答 问题 的 节奏 最 好 不 要 太 慢 ， 也 不 要 太 快 ， 


提交 给 面试 官 ， 最 好 能 够 利用 剩余 的 时 间 ， 认 真 仔细 


地 检查 一 些 边 界 情况 、 异 常情 况 及 极 性 情况 等 ， 看 是 否 也 能 满足 要 求 。 


(5) 规范 编码 
回答 技术 性 
对 自己 的 代码 一 看 
范 : 函数 变量 命名 、 


] 情 


问题 时 ， 多 数 都 是 纸 上 写 代码 ， 离 7 


于 了 编译 器 的 帮助 ， 求 职 者 要 想 让 面试 


E， 除 了 字迹 要 工 


整 ， 不 能 眉飞色舞 以 外 ， 最 好 


= 
Ex 


月. 台 尼 


够 严格 遵循 编码 规 


古 了 有 


换行 缩 进 、 语 句 嵌 套 和 代码 布局 等 ， 同 时 ， 代 码 设计 应 该 具有 完整 性 ， 


保证 代码 能 够 完成 基本 
能 够 做 出 合理 的 错误 处 理 ， 
LE 常 费劲， 这 些 对 


起 来 


(6) 精心 测试 


许 错误 百出 。 万 
间 内 设计 出 的 算法 ， 
的 范围 内 。 


测试 代码 是 让 代码 变 得 完备 的 高 效 方式 之 一 ， 也 是 一 名 优秀 程序 员 ， 


其 是 如 


功能 、 输 入 边界 值 能 够 得 至 
否则 ， 写 剖 


I 正确 


地 输出 、 对 各 种 不 合 规范 的 非法 输入 


在 软件 界 ， 有 一 句 真 理 : 任何 软件 都 有 bug。 但 不 能 医 
面试 过 程 中 ， 


各 种 


车 = = 
开 甫 不合 


都 得 


口 


以 ， 在 编写 代码 前 ， 求 职 者 最 好 能 够 了 解 一 些 基本 的 测试 知 
能 测试 、 边 界 测试 以 及 异 汕 六 
回答 技术 性 问题 时 ， 注 意 在 思考 问题 的 时 候 ， 生 万 别 
时 间 是 有 限 的 ， 他 们 希望 在 有 限 的 时 间 内 尽 可 能 地 去 了 解 求职 者 ， 如 果 求 职 者 坐 在 那里 


疏 


名 话 不 说 ， 不 仅 会 让 面试 


存在 问题 。 
其 实 ， 在 面试 时 


面试 过 程 中 的 技术 性 问题 ， 结 果 
包括 求职 者 在 解决 问题 的 过 程 中 


仅 是 最 终 的 结果 ， 还 


I 试 。 


的 代码 即使 无 比 高 效 ， 
试 成 功 都 是 非常 不 利 的 。 


实现 功能 也 许 并 不 十 分 
到 了 有 效 的 处 理 ， 各 种 边界 值 是 否 都 在 算法 设计 


面试 官 也 不 一 定 看 得 懂 或 者 看 


为 如 此 就 纵容 自己 的 代码 ， 允 


困难 ， 困 难 的 是 在 有 限 的 时 


六 备 的 素质 之 一 。 记 
做 一 些 基 本 的 单元 测试 、 功 


识 


MA AN 


= 
上 昌 贤 得 


句 话 都 不 说 ， 面 试 官 面试 的 


pe 


， 求 职 者 往 


人 


固然 重要 ， 但 也 并 


能 力 。 所 以 ， 求 职 


在 与 面试 官 


求职 者 技术 水 平 不 行 ， 


的 博弈 中 ， 要 适当 地 提问 ， 通 过 提问 获取 面试 官 的 反馈 信 


思考 问题 能 力 以 及 沟 


通 能 力 可 能 都 


E 会 存在 一 种 思想 误区 ， 把 技术 性 面试 的 结果 看 得 太 重 要 了 。 


FE 最 重要 的 内 容 ， 因 为 面试 官 看 重 的 不 仅 
体现 出 来 的 逻辑 思维 能 力 以 及 分 析 问 题 的 
息 


4 


并 抓 住 这 些 有 用 的 信息 进行 辅助 思考 ， 从 而 博得 面试 官 的 欢心 ， 进 而 提高 面试 的 成 功率 。 


可 试 笔试 经 验 技巧 篇 


如 何 回答 非 技术 性 问题 ? 


评价 一 个 人 的 能 力 ， 除 了 专业 能 力 ， 还 有 一 些 非 专业 能 力 ， 如 智力 、 沟 通 能 力 和 反应 能 
力 等 ， 所 以 在 IT 企业 招聘 过 程 的 笔试 面试 环节 中 ， 并 非 所 有 的 笔试 内 容 都 是 CCC++、 数 据 结 
构 与 算法 及 操作 系统 等 专业 知识 ， 也 包括 其 他 一 些 非 技术 类 的 知识 ， 如 智力 题 、 推 理 题 和 作 
文 题 等 。 技 术 水 平 测试 可 以 考查 一 个 求职 者 的 专业 素养 ， 而 非 技术 类 测试 则 更 加 强调 求职 者 
的 综合 素质 ， 包 括 数学 分 析 能 力 、 反 应 能 力 、 临 场 应 变 能 力 、 思 维 灵 活性 、 文 字 表 达能 力 和 
性 格 特征 等 内 容 。 考 查 的 形式 多 种 多 样 ， 但 与 公务 员 考 查 相 似 ， 主 要 包括 行 测 ( 占 大 多 数 )、 
性 格 测试 (大 部 分 都 有 )、 应 用 文 和 开放 问题 等 内 容 。 

每 个 人 都 有 自己 的 答题 技巧 ， 答 题 方式 也 各 不 相同 ， 以 下 是 一 些 相对 比较 好 的 答题 技巧 
以 行 测 为 例 ): 

1) 合理 有 效 的 时 间 管 理 。 由 于 题目 的 难 易 不 同 ， 所 以 不 要 对 所 有 题目 都 “绝对 的 公 
平 ” 都 “一 思 切 ”要 有 和 轻重缓急， 最 好 的 做 法 是 不 按 顺 序 回答 。 行 测 中 有 各 种 题 型 ， 
如 数量 关系 、 图 形 推理 、 应 用 题 、 资 料 分 析 和 文字 逻辑 等 ， 而 不 同 的 人 擅长 的 题 型 是 不 
一 样 的 ， 因 此 应 该 首先 回答 自己 最 擅长 的 问题 。 例 如 ， 如 果 对 数字 比较 敏感 ， 那 么 就 先 
答 数 量 关系 。 

2) 注意 时 间 的 把 握 。 由 于 题 量 一 般 都 比较 大 ， 可 以 先 按照 总 时 间 / 题 数 来 计算 每 道 题 的 
平均 答题 时 间 ， 如 10s， 如 果 看 到 某 一 道 题 5s 后 还 没 思路 ， 则 马上 放弃 。 在 做 行 测 题 目的 时 
候 ， 以 在 最 短 的 时 间 内 拿 到 最 多 分 为 目标 。 

3) 平时 多 关注 图 表 类 题目 ， 培 养 迅速 抓 住 图 表 中 各 个 数字 要 素 间 相互 迪 辑 关系 的 能 

4) 做 题 要 集中 精力 ， 只 有 集中 精力 、 人 全神贯注 ， 才 能 将 自己 的 水 平 最 大 限度 地 发 挥 
出 来 。 

5) 学 会 关键 字 查 找 ， 通 过 关键 字 查 找 ， 能 够 提高 做 题 效 率 。 

6) 提高 估算 能 力 ， 有 很 多 时 候 ， 估 算 能 够 极 大 地 提高 做 题 速度 ， 同 时 保证 正确 率 。 

除了 行 测 以 外 ， 一 些 企业 非常 相信 个 人 性 格 对 入 职 匹配 的 影响 ， 所 以 都 会 引入 相关 的 性 
格 测试 题 用 于 测试 求职 者 的 性 格 特性 ， 看 其 是 否 适合 所 投递 的 职位 。 大 多 数 情况 下 ， 只 要 按 
照 自己 的 真实 想法 选择 就 行 了 ， 不 要 弄巧成拙 ， 因 为 测试 是 为 了 得 出 正确 的 结果 ， 所 以 大 多 
测试 题 前 后 都 有 相互 验证 的 题目 。 如 果 求 职 者 自作 聪明 ， 选 择 该 职位 可 能 要 求 的 性 格 选项 ， 则 
很 可 能 导致 测试 前 后 不 符 ， 这 样 很 容易 让 企业 发 现 你 是 个 不 诚实 的 人 ， 从 而 首先 予以 筛 除 。 


如 何 回答 快速 估算 类 问题 ? 


有 些 大 企业 的 面试 官 ， 总 喜欢 使 一 些 “ 阴 招 ”“ 损 招 ” 出 一 些 快速 估算 类 问题 ， 对 他 们 
而 言 ， 这 些 问题 只 是 手段 ， 不 是 目的 ， 能 够 得 到 一 个 满意 的 结果 固然 是 他 们 所 需要 的 ， 但 更 
重要 的 是 通过 这 些 题目 他 们 可 以 考查 求职 者 的 快速 反应 能 力 以 及 逻辑 思维 能 力 。 由 于 求职 者 
平时 准备 的 时 候 可 能 对 此 类 问题 有 所 遗漏 ， 一 时 很 难 想 起 解决 的 方案 。 而 且 ， 这 些 题目 乍 一 
看 确实 是 毫 无 头绪 ， 无 从 下 手 ， 完 全 就 是 坑 求 职 者 的 ， 其 实 求职 者 只 要 从 惊慌 失措 中 冷静 下 


hy 


Ps 


日 


Java 和 和 


序 员 


而 


产 


可 试 笔 试 真 


来 ， 稍 加 分 析 ， 也 识 
案 ， 只 要 和 弄 清楚 了 回答 要 点 ， 分 析 合 型 


一 点 都 不 困难 。 


例如 ， 


额 ? ” 
的 ， 妇 


ee 


日 


试 官 可 


内 


ti 那么 回 寻 


| 
能 会 


= 


因为 


Fo 


问 这 样 一 个 问题 : 


上 


属于 开放 
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目 比 较 灵活 ， 
EE 到位， 具有 说 服 力 ， 能 够 


类 题 


圆 


三 | 
征 


， 求 职 者 又 不 


统计 局 官员 ， 如 何 能 够 得 出 一 个 准 胡 
1 何 能 够 得 出 一 个 ; 准 


明明 白白 吧 ? 


| 


数据 ， 


商场 规模 、 商 外 


构成 ， 


即 可 得 到 促销 时 


而 分 析 概 数 


尾道 此 题 就 无 解 了 吗 ? 其 实 不 然 ， 本 题 只 要 能 
的 前 提 就 是 做 出 各 种 假设 。 


得 到 全 商场 


和 规模 入 手 ， 通 过 每 平方 米 的 租 


日 均 交 易 额 ， 再 考虑 促销 时 的 销 


“请 你 估算 一 下 一 家 商场 在 促 外 
第 的 数据 呢 ? 求职 者 家 又 不 是 开 商 场 


全 试 题 ， 一 般 没 有 标准 答 


其 说 ， 就 是 


E 确 


里 
| 


交 
答案 ， 


省 时 一 天 的 营业 


第 的 数据 呢 ? 即使 求职 者 是 商场 的 大 当家 ， 也 不 可 


金 ， 估 算出 商场 的 日 租 


分 析出 一 个 概 数 就 行 了 ， 不 
以 该 问题 为 例 ， 可 以 尝试 从 以 下 思路 入 手 : 从 
和 的 成 本 


台 玉 让 


且 天 从 


证 


清楚 楚 


定 要 精确 


金 ， 再 根据 商 钊 


3l 


明 售 额 与 平时 销 人 


60000m 的 面积 。 


2 
3 


4) 对 商户 而 言 ， 租 金 一 般 占 销 售 
平均 日 销售 额 为 21.9 


) 商人 
) 商 钊 


天 的 营业 额 。 


具体 而 言 ， 包 括 以 下 估计 数值 : 
1) 以 一 家 较 大 规模 商场 为 例 ， 商 场 一 般 按 6 层 计 算 ， 每 


和 规模 占 商 场 规模 的 一 半 左 右 ， 合 计 30000m”。 
和 和 金 约 为 40 元 /m， 估 算出 年 租金 为 40X30000X365=4.38 亿 。 


Z/365=600 万 。 


额 20% 左 右 ， 则 年 名 


售 额 的 倍数 关系 ， 乘 以 倍数 ， 


层 大 约 长 100m， 宽 100m， 合 计 


省 售 额 为 4.38 亿 X5=21.9 亿 。 计 算 


5) 促销 时 的 日 销售 额 一 般 是 平时 的 10 倍 ， 所 以 大 约 为 600 万 *10=6000 万 。 

此 类 题目 涉及 面 比 较 广 ， 例 如 : 估算 一 下 北京 小 吃 店 的 数量 ?估算 一 下 中 国 在 过 去 一 年 
方便 面 的 市 场 销售 额 是 多 少 ? 估算 一 下 长 江 的 水 的 质量 ?估算 一 下 一 个 行进 在 小 雨中 的 人 
5min 内 身上 淋 到 的 雨 的 质量 ? 估算 一 下 东方 明珠 电视 塔 的 质量 ? 估算 一 下 中 国 去 年 一 年 一 共 
用 掉 了 多 少 块 尿 布 ? 估算 一 下 杭州 的 轮胎 数量 ?但 一 般 都 是 即兴 发 挥 ， 不 是 哪 道 题记 住 答案 
就 可 以 应 付 得 了 的 。 过 到 此 类 问题 ， 一 步 步 抽 丝 剥 前， 才 是 解决 之 道 。 


如 何 回答 算法 设计 问题? 


程序 员 面 试 
对 算法 知识 学 习 得 是 否 扎实 ， 到 


者 早 前 编号 的 一 本 书 ， 由 机 械 工 业 出 版 社 出 版 )， 学 习 上 一 段 时 间 ， 
完全 没有 问题 ， 但 遗憾 的 是 ， 很 多 世界 级 知名 企业 也 深 知 这 一 点 ， 妇 


含量 的 题目 ， 对 于 考 前 
常 不 公平 的 。 所 以 ， 为 了 把 优秀 的 求职 者 与 一 般 的 求职 者 能 够 更 好 地 区 分 3 


年 推陈出新 ， 越 来 越 倾向 


FP 的 很 多 算法 设计 问题 ， 都 是 历年 来 各 家 企业 的 “ 炒 现 饭 ”不管 求生 


6 DR 


全 


四 


LE 解 得 是 否 深入 ， 只 要 面试 前 买 本 《程序 员 


和 


出 一 些 有 


技术 含量 的 “新 ” 题 ， 这 些 题 


目 


的 陈 谷子 烂 芝麻 了 ， 而 是 经 过 精心 设计 的 好 题 。 


在 程序 员 面 试 中 , 算法 的 地 位 就 如 同 是 GRE 或 托福 考试 在 出 国 留学 中 下 
但 不 是 最 重要 的 ， 它 只 是 众多 考核 方面 中 的 一 个 而 已 ， 不 一 定 就 能 决定 求职 者 的 9 


如 此 ， 但 并 非 说 就 不 用 去 准备 算法 知识 了 ， 因 为 算法 知识 
项 ， 对 于 求 有 


只 成 功 ， 百 利 而 无 一 害 。 那 么 如 何 应 对 此 类 题目 呢 ? 很 


显 


1 


FE 记 于 心 ， 
I 果 纯粹 是 出 一 些 毫 无 技 
手 ” 而 言 ， 可 能 会 占 尽 便宜 ， 但 对 于 那些 技术 好 的 人 而 言 是 
也 们 会 年 
再 是 以 前 


口 
A\ 


看 试 笔试 宝典 》( 编 


者 以 前 


应 付出 


开 来 ，1 


类 题 


是 页 HH 


以 及 答案 ， 不 


的 地 位 一 样 ， 必 须 
E 死 。 虽 然 
回答 得 好 ， 必 然 会 成 为 面试 的 加 分 
然 ， 编 者 不 可 能 


将 此 类 


可 试 笔试 经 验 技巧 篇 


题目 都 在 《程序 员 面 试 笔试 宝典 》 中 一 一 解答 ， 一 来 由 于 内 容 众 多 ， 篇 幅 有 限 ， 二 来 也 没 必 
要 ， 今 年 考 过 了 ， 以 后 一 般 就 不 会 再 考 了 ， 不 然 还 是 没有 区 分 度 。 编 者 以 为 ， 靠 死记 人 硬 背 肯 
定 是 行 不 通 的 ， 解答 此 类 算法 设计 问题 ,需要 求职 者 具有 扎实 的 基本 功 以 及 良好 的 运用 能 力 ， 
编者 无 法 左右 求职 者 的 个 人 基本 功 以 及 运用 能 力 ， 因 为 这 些 能 力 需 要 求职 者 “十 年 磨 一 剑 ” 
地 苦 学 ， 但 编者 可 以 提供 一 些 比较 好 的 答题 方法 和 解 题 思 路 ， 以 供求 职 者 在 面试 时 应 对 此 类 
算法 设计 问题 。“ 授 之 以 鱼 不 如 授 之 以 渔 ” 岂 不 是 更 好 ? 

(1) 归纳 法 
此 方法 通过 写 出 问题 的 一 些 特定 的 例子 ,分 析 总 结 其 中 一 般 的 规律 。 具 体 而 言 就 是 通 } 
列举 少量 的 特殊 情况 ， 经 过 分 析 ， 最 后 找 出 一 般 的 关系 。 例 如 ， 某 人 有 一 对 兔子 饲养 在 转 
中 ， 如 果 它 们 每 个 月 生 一 对 兔子 ， 且 新 后 的 兔子 在 第 二 个 月 后 也 是 每 个 月 生 一 对 兔子 ， 问 
年 后 围墙 中 共有 多 少 对 兔子 。 
使 用 归纳 法 解答 此 题 ， 首 先 想到 的 就 是 第 一 个 月 有 多 少 对 兔子 ， 第 一 个 月 的 时 候 ， 最 初 
的 一 对 兔子 生 下 一 对 兔子 ， 此 时 围墙 内 共有 两 对 兔子 。 第 二 个 月 仍 是 最 初 的 一 对 兔子 生 下 
对 兔子 ， 共 有 3 对 兔子 。 到 第 三 个 月 除 最 初 的 兔子 新 生 一 对 兔子 外 ， 第 一 个 月 生 的 兔子 也 开 
台 和 后 兔子 ， 因 此 共有 5 对 兔子 。 通 过 举例 ， 可 以 看 出 ， 从 第 二 个 月 开始 ， 每 一 个 月 兔子 总 数 
都 是 前 两 个 月 兔子 总 数 之 和 ，UnH=Un+Un_1， 一 年 后 ， 围 墙 中 的 兔子 总 数 为 377 对 。 

此 种 方法 比较 抽象 ， 也 不 可 能 对 所 有 的 情况 进行 列举 ， 所 以 ， 得 出 的 结论 只 是 一 种 猜测 ， 
还 需要 进行 证 明 。 

(2) 相似 法 

正如 编者 “年 年 岁 岁 花 相 似 ， 岁 岁 年 年 仍 单身 ”一 样 ， 此 方法 考虑 解决 问题 的 算法 是 相 
似 的 。 如 果 面 试 官 提 出 的 问题 与 求职 者 以 前 用 某 个 算法 解决 过 的 问题 相似 ， 此 时 此 刻 就 可 以 
触 类 旁 通 ， 尝 试 改进 原 有 算法 来 解决 这 个 新 问题 。 而 通常 情况 下 ， 此 种 方法 都 会 比较 奏效 。 

例如 ， 实 现 字符 串 的 逆序 打印 ， 也 许 求 职 者 从 来 就 没 遇 到 过 此 问题 ， 但 将 字符 串 逆序 肯定 
在 求职 准备 的 过 程 中 是 见 过 的 。 将 字符 串 逆 序 的 算法 稍 加 处 理 ， 即 可 实现 字符 串 的 逆序 打印 。 

(3) 简化 法 

此 方法 首先 将 问题 简单 化 ， 例 如 改变 一 下 数据 类 型 、 空 间 大 小 等 ， 然 后 尝试 着 将 简化 后 
的 问题 解决 ， 一 旦 有 了 一 个 算法 或 者 思路 可 以 解决 这 个 被 “ 阁 割 过 ”的 问题 ， 再 将 问题 还 原 ， 
尝试 着 用 此 类 方法 解决 原 有 问题 。 
例如 ， 在 海量 日 志 数 据 中 提取 出 某 日 访问 xxx 网 站 次 数 最 多 的 那个 IP。 很 显然 ， 由 于 数 
据 量 巨大 ， 直 接 进 行 排序 不 可 行 ， 但 如 果 数 据 规模 不 大 时 ， 采 用 直接 排序 不 失 为 一 种 好 的 解 
决 方法 。 那 么 如 何 将 问题 规模 缩小 呢 ? 于 是 想到 了 Hash 法 ，Hash 往往 可 以 缩小 问题 规模 ， 
然后 在 “ 阁 制 过 ”的 数据 里 面 使 用 常规 排序 算法 即 可 找 出 此 问题 的 答案 。 

(4) 递归 法 

为 了 降低 问题 的 复杂 度 ， 很 多 时 候 都 会 将 问题 逐 层 分 解 ， 最 后 归结 为 一 些 最 简单 的 问题 ， 
这 就 是 递归 。 此 各 方法， 首先 要 能 够 解决 最 基本 的 情况 ， 然 后 以 此 为 基础 ， 解 决 接 下 来 的 问题 。 
例如 ， 在 寻求 全 排列 的 时 候 ， 可 能 会 感觉 无 从 下 手 ， 但 仔细 推 殴 ， 会 发 现 后 一 种 排列 组 
往往 是 在 前 一 种 排列 组 合 的 基础 上 进行 的 重新 排列 ， 上 只 要 知道 了 前 一 种 排列 组 合 的 各 类 组 
情况 ， 只 需 将 最 后 一 个 元 素 插 入 到 前 面 各 种 组 合 的 排列 里 面 ， 就 实现 了 目标 : 即 先 截 去 字 
守 捉 s[1...n] 中 的 最 后 一 个 字母 ， 生 成 所 有 s[1...n-1] 的 全 排列 ， 然 后 再 将 最 后 一 个 字母 插入 到 


请 他 


慌 政 悄 
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每 一 个 可 插入 的 位 置 。 


(5) 分 治 法 
任 


任 以 直接 解决 的 大 问题 ， 


法 一 般 包含 以 下 三 个 步骤 ， 
1) 将 问题 的 实例 划分 为 几 个 较 小 的 实例 ， 最 好 具有 相等 的 规模 。 
2) 对 这 些 较 小 的 实例 求解 ， 而 最 常见 的 方法 一 般 是 递归 。 


3) 如 果 有 必要 ， 合 并 这 些 较 小 问题 的 解 ， 以 得 至 


可 一 个 可 以 用 计算 机 求解 的 问题 所 需 的 计算 时 间 都 与 其 规模 有 关 。 问 题 的 规模 越 小 ， 
越 容易 直接 求解 ， 解 题记 需 的 计算 时 间 也 越 少 。 而 分 治 法 


分 割 成 一 些 规模 较 小 的 相同 问题 ， 


分 治 法 是 程序 员 面试 常 考 的 算法 之 
组 和 、 找 出 伪 币 、 金 块 问 题 、 矩 阵 乘法 、 残 缺 棋 盘 、 归 并 排序 、 快 速 排序 、 距 离 最 近 的 点 对 、 
导线 与 开关 等 。 


(6) Hash 法 


很 多 面试 笔试 题目 ， 都 要 求 求职 者 给 出 的 算法 尽 可 能 高 交 


般 而 言 ， 时 间 复 杂 度 越 


空间 上 有 所 牺牲 ， 用 空间 来 换 时 间 。 
图 法 。 当 然 ， 
求职 者 只 能 


表 、 二 又 树 或 图 
候 并 不 确 
编者 建议 ， 此 时 ， 求 职 者 可 以 采 上 月 
各 种 可 能 的 数据 结构 与 算法 ， 常 考 的 数据 结构 与 算法 


而 月 


此 类 方法 3 


(7) 轮 询 法 


于 去 思考 其 他 的 方法 了 。 
其 实 ， 几 是 涉及 大 规模 数据 处 


非 包 治 百 病 ， 


有 


时， 


的 算法 自 


E 是 充分 考虑 到 这 一 内 容 ， 将 一 个 


以 便 各 个 击破 ， 分 而 治之 。 分 治 


I 原始 问题 的 解 。 
般 适用 于 二 分 查找 、 大 整数 相 乘 、 求 最 大 子 数 


。 什 么 样 的 算法 是 高 效 的 ? 一 


氏 的 算法 越 高 效 。 而 要 想 达 到 时 间 复 杂 度 的 高 效 ， 很 多 时 候 就 必须 在 


日 空间 换 时 间 最 有 效 的 方式 就 是 Hash 法 、 大 数组 和 位 


然而 然 地 就 会 暴露 出 来 。 


用 试 官 也 会 对 空间 大 小 进行 限制 ， 那 么 此 时 ， 


理 的 算法 设计 中 ，Hash 法 就 是 最 好 的 方法 之 一 。 


在 设计 每 道 面 试 笔 试题 时 ， 往 往 会 有 一 个 载体 ， 这 个 载体 便 是 数据 结构 ， 例 如 数组 、 链 
等 ， 当 载体 确定 后 ， 可 月 
定 这 个 载体 是 什么 。 当 无 法 确定 这 个 载体 时 ， 一 般 也 就 很 难 想到 合适 的 方法 了 。 

昌 最 原始 的 思考 问题 的 方法 一 一 轮 询 法 ， 在 脑海 中 轮 询 
一 共 就 那么 几 种 〈 见 表 1)， 即 使 不 完全 


可 问题 是 很 多 时 


样 ， 也 是 由 此 衍生 出 来 的 或 者 相似 的 ， 总 有 一 款 适 合 考题 的 。 
表 1 最 常 考 的 数据 结构 与 算法 知识 点 
数据 结构 算 法 概 念 
链表 广度 〈 深 度 ) 优先 搜索 位 操作 
数组 递归 设计 模式 
-又 树 -分 查找 内 存 管理 〈 堆 、 栈 等 ) 
树 排序 (归并 排序 、 快 速 排序 等 ) 
堆 〈 大 项 扒 、 小 项 堆 ) 树 的 插入 /删除 /查找 /遍历 等 
栈 图 论 
队列 Hash 法 
向 量 分 治 法 
Hash 表 动态 规划 
此 种 方法 看 似 笨拙 ， 其 实 实用 ， 只 要 求职 者 对 常见 的 数据 结构 与 算法 烂熟 于 心 ， 一 点 都 


面试 笔试 经 验 技 巧 篇 


没有 问题 。 

为 了 更 好 地 理解 这 些 方法 ， 求 职 者 可 以 在 平时 的 准备 过 程 中 ， 应 用 此 类 方法 去 答题 ， 做 
得 多 了 ， 自 然 对 各 种 方法 也 就 熟 能 生 巧 了 ， 面 试 的 时 候 ， 再 过 到 此 类 问题 ， 也 就 能 够 收 放 自 
如 了 。 当 然 ， 千 万 不 要 相信 有 着 张无忌 般 的 运气 ， 能 够 在 一 夜 之 间 练 成 乾坤 大 挪移 这 一 绝世 
功 ， 称 霸 武 林 ， 算 法 设计 功力 的 练 就 是 平时 一 点 一 滴 的 付出 和 思维 的 磨 练 。 方 法 与 技巧 也 
许 上 只 是 给 面试 打 了 一 针 “ 鸡 血 ” 喂 一 口 “ 大 补 丸 ” 不 会 让 自己 变 得 从 容 自信 ， 真 正 的 功力 
还 是 需要 一 个 长 期 的 积累 过 程 的 。 


如 何 回答 系统 设计 题 ? 


应 届 生 在 面试 的 时 候 ， 偶 尔 也 会 遇 到 一 些 系统 设计 题 ， 而 这 些 题目 往往 只 是 测试 一 下 求 
职 者 的 知识 面 ， 或 者 测试 求职 者 对 系统 架构 方面 的 了 解 ， 一 般 不 会 涉及 具体 的 编码 工作 。 虽 
然 如 此 ， 对 于 此 类 问题 ， 很 多 人 还 是 感觉 难以 应 对 ， 也 不 知道 从 何 说 起 。 

如 何 应 对 此 类 题目 呢 ? 在 正式 介绍 基础 知识 之 前 ， 首 先 罗列 几 个 常见 的 系统 设计 相关 的 
面试 笔试 题 ， 如 下 所 示 : 

1) 设计 一 个 DNS 的 Cache 结构 ， 要 求 能 够 满足 每 秒 5000 次 以 上 的 查询 ， 满 足 IP 数据 
的 快速 插入 ， 查 询 的 速度 要 快 〈 题 目 还 给 出 了 一 系列 的 数据 ， 比 如 站 点 数 总 共 为 5000 万 、IP 
地 址 有 1000 万 等 )。 

2) 有 NN 台 机 器 ，M 个 文件 ， 文 件 可 以 以 任意 方式 存放 到 任意 机 器 上 ， 文 件 可 任意 分 割 
成 知 干 块 。 假 设 这 N 台 机 器 的 宕 机 率 小 于 1/3, 想 在 宕 机 时 可 以 从 其 他 未 宕 机 的 机 器 中 完整 导 
出 这 M 个 文件 ， 求 最 好 的 存放 与 分 割 策略 。 

3) 假设 有 三 十 台 服 务 器 ， 每 台 服 务 器 上 面 都 存 有 上 百 亿 条 数据 (有 可 能 重复 )， 如 何 找 出 这 
三 十 台 机 器 中 ， 根 据 某 关 键 字 ， 重 复出 现 次 数 最 多 的 前 100 条 ?要求 使 用 Hadoop 来 实现 。 

4) 设计 一 个 系统 ， 要 求 写 速度 尽 可 能 快 ， 并 说 明 设 计 原 理 。 

5) 设计 一 个 高 并 发 系统 ， 说 明 架 构 和 关键 技术 要 点 。 

6) 有 25T 的 log(query->queryinfo)，log 在 不 断 地 增长 ， 设 计 一 个 方案 ， 给 出 一 个 query 
能 快速 返回 queryinfo。 

以 上 所 有 问题 中 凡是 不 涉及 高 并 发 的 ， 基 本 可 以 采用 Google 的 三 个 技术 解决 ， 即 GFS、 
MapReduce 和 Bigtable， 这 三 个 技术 被 称 为 “Google 三 蜀 马 车 ” Google 只 公开 了 论文 而 未 开 
源 代 码 ， 开 源 界 对 此 非常 有 兴趣 ， 仿 照 这 三 篇 论文 实现 了 一 系列 软件 ， 如 Hadoop、HBase、 
HDFS 及 Cassandra 等 。 

在 Google 这 些 技术 还 未 出 现 之 前 ， 企 业界 在 设计 大 规模 分 布 式 系统 时 ， 采 用 的 架构 往往 
是 database+sharding+cache， 现 在 很 多 公司 《比如 taobao、weibo.com) 仍 采 用 这 种 架构 。 在 
这 种 架构 中 ， 仍 有 很 多 问题 值得 去 探讨 。 如 采用 什么 数据 库 ， 是 SQL 界 的 MySQL 还 是 
NoSQL 界 的 Redis/TFS， 两 者 有 何 优 和 劣 ? 采用 什么 方式 sharding (数据 分 片 ;， 是 水 平分 
片 还 是 垂直 分 片 ? 据 网 上 资料 显示 ，weibo.com 和 taobao 图 片 存 储 中 曾 采 用 的 架构 是 
Redis/MySQL/TFS+shardingtcache， 该 架构 解释 如 下 : 前 端 cache 是 为 了 提高 响应 速度 ， 后 端 
数据 库 则 用 于 数据 永久 存储 ， 防 止 数据 丢失 ， 而 sharding 是 为 了 在 多 台 机 器 间 分 挫 负 载 。 最 
前 端 由 大 块 大 块 的 cache 组 成 ， 要 保证 至 少 99%〔 该 数据 在 weibo.com 架构 中 的 是 自己 猜 的 ， 


一 
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而 taobao 图 片 存储 模块 是 真实 的 ) 的 访问 数据 落 在 cache 中 ， 这 样 可 以 保证 用 户 访问 速度 ， 
减少 后 端 数据 库 的 压力 。 此 外 ， 为 了 保证 前 端 cache 中 的 数据 与 后 端 数据 库 中 的 数据 一 致 ， 
需要 有 一 个 中 间 件 异步 更 新 (为 什么 使 用 异步 ? 理由 简单 : 同步 代价 太 高 。 异 步 有 缺点 ， 如 
何 弥 补 ?) 数据 ， 这 个 有 些 人 可 能 比较 清楚 ， 新 浪 有 个 开源 软件 叫 Memcachedb 整合 
Berkeley DB 和 Memcached)， 正 是 完成 此 功能 。 男 外 ， 为 了 分 挫 负 载 压 力 和 海量 数据 ， 会 将 
用 户 微 博信 息 经 过 分 片 后 存放 到 不 同 节点 上 称 为 “Sharding”)。 

这 种 架构 优点 非常 明显 : 简单 ， 在 数据 量 和 用 户 量 较 小 的 时 候 完 全 可 以 胜任 。 但 缺点 是 
扩展 性 和 容错 性 太 差 ， 维护 成 本 非常 高 ， 尤 其 是 数据 量 和 用 户 量 暴 增 之 后 ， 系 统 不 能 通过 简 
单 地 增加 机 器 解决 该 问题 。 

鉴于 此 ， 新 的 架构 应 运 而 生 。 新 的 架构 仍然 采用 Google 公司 的 架构 模式 与 设计 思想 ， 以 
下 将 分 别 就 此 内 容 进 行 分 析 。 

GFS 是 一 个 可 扩展 的 分 布 式 文件 系统 ， 用 于 大 型 的 、 分 布 式 的 、 对 大 量 数据 进行 访问 的 
应 用 。 它 运行 于 廉价 的 普通 硬件 上 ， 提 供 容 错 功 能 。 现 在 开源 界 有 HDFS (Hadoop Distributed 
File System)， 该 文件 系统 虽然 弥补 了 数据 库 +sharding 的 很 多 缺点 ， 但 自身 仍 存在 一 些 问 题 ， 
比如 : 由 于 采用 masterslave 架构 ， 因 此 存在 单 点 故障 问题 ， 元 数据 信息 全 部 存放 在 master 
端的 内 存 中 ， 因 而 不 适合 存储 小 文件 ， 或 者 说 如 果 存 储 大 量 小 文件 ， 那 么 存储 的 总 数据 量 不 
会 太 大 。 

MapReduce 是 针对 分 布 式 并 行 计 算 的 一 套 编程 模型 。 其 最 大 的 优点 是 : 编程 接口 简 
自动 备份 〈 数 据 默认 情况 下 会 自动 备 三 份 )， 自 动容 错 和 隐藏 跨 机 器 间 的 通信 。 在 Hadoop 中 ， 
MapReduce 作为 分 布 计算 框架 ， 而 HDFS 作为 底层 的 分 布 式 存储 系统 ， 但 MapReduce 不 是 与 
HDFS 耦合 在 一 起 的 ， 完 全 可 以 使 用 自己 的 分 布 式 文件 系统 替换 掉 HDFS。 当 前 MapReduce 
有 很 多 开源 实现 ， 如 Java 实现 Hadoop MapReduce，C++ 实 现 Sector/sphere 等 ， 甚 至 有 些 数据 
库 厂 商 将 MapReduce 集成 到 数据 库 中 了 。 

BigTable 俗称 “大 表 ” 是 用 来 存储 结构 化 数据 的 ， 编 者 觉得 ，BigTable 在 开源 界 最 火爆 ， 
其 开源 实现 最 多 ， 包 括 HBase、Cassandra 和 levelDB 等 ， 使 用 也 非常 广泛 。 

除了 Google 的 这 “三 驾 马 车 ”以 外 ， 还 有 其 他 一 些 技术 可 供 学 习 与 使 用 : 

Dynamo: 亚马逊 的 key-value 模式 的 存储 平台 ， 可 用 性 和 扩展 性 都 很 好 ， 采 用 DHT 
(Distributed Hash Table) 对 数据 分 片 ， 解 决 单 点 故障 问题 ,在 Cassandra 中 ,也 借鉴 了 该 技术 ， 
在 BT 和 电驴 这 两 种 下 载 引擎 中 ， 也 采用 了 类 似 算法 。 

虚拟 节点 技术 : 该 技术 常用 于 分 布 式 数据 分 片 中 。 具 体 应 用 场景 是 ， 有 一 大 块 数据 (可 
能 TB 级 或 者 PB 级 )， 需 按照 某 个 字段 (key) 分 片 存储 到 几 十 (或 者 更 多 ) 台 机 器 上 ， 同 时 想 
尽量 负载 均衡 上 且 容 易 扩展 。 传 统 的 做 法 是 :Hash(key) mod N， 这 种 方法 最 大 的 缺点 是 不 容易 扩 
展 ， 即 增加 或 者 减少 机 器 均 会 导致 数据 全 部 重 分 布 ， 代 价 太 大 。 于 是 新 技术 诞生 了 ， 其 中 一 种 
是 上 面 提 到 的 DHT， 现 在 已 经 被 很 多 大 型 系统 采用 ， 还 有 一 种 是 对 “Hash(key) modN ”的 改进 : 
假设 要 将 数据 分 布 到 20 台 机 器 上 ， 传 统 做 法 是 Hash(key) mod 20， 而 改进 后 ，N 取 值 要 远大 于 
20， 比 如 是 20000000， 然 后 采用 额外 一 张 表 记 录 每 个 节点 存储 的 key 的 模 值 ， 比 如 : 

nodel: 0~1000000 

node2: 1000001~2000000 


[| 


曙 
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这 样 ， 当 添加 一 个 新 的 节点 时 ， 只 需 将 每 个 节点 上 部 分 数据 移动 给 新 节点 ， 同 时 修改 一 
下 该 表 即 可 。 

Thrift，Thrift 是 一 个 跨 语 言 的 RPC 框架 ,分别 解释 “RPC” 和 “ 跨 语 言 ”如 下 : RPC 是 
远程 过 程 调用 ， 其 使 用 方式 与 调用 一 个 普通 函数 一 样 ， 但 执行 体 发 生 在 远程 机 器 上 ; 跨 语 言 
是 指 不 同 语言 之 间 进 行 通信 ， 比 如 C/S 架构 中 ，Server 端 采用 C++ 编写 ，Client 端 采用 PHP 
编写 ， 怎 样 让 两 者 之 间 通 信 ，Thrift 是 一 种 很 好 的 方式 。 

本 篇 最 前 面 的 几 道 题 均 可 以 映射 到 以 上 几 个 系统 的 某 个 模块 中 ， 如 : 

1) 关于 高 并 发 系统 设计 ， 主 要 有 以 下 几 个 关键 技术 点 : 缓存 、 索 引 、 数 据 分 片 及 锁 粒 度 
尽 可 能 小 。 

2) 题目 2 涉及 现在 通用 的 分 布 式 文件 系统 的 副本 存放 策略 。 一 般 是 将 大 文件 切 分 成 小 的 
block (如 64MB) 后 ， 以 block 为 单位 存放 三 份 到 不 同 的 节点 上 ， 这 三 份 数据 的 位 置 需 根据 网 
络 拓扑 结构 配置 ， 一 般 而 言 ， 如 果 不 考 虑 跨 数据 中 心 ， 可 以 这 样 存放 : 两 个 副本 存放 在 同一 
个 机 架 的 不 同 节 点 上 ， 而 另外 一 个 副本 存放 在 另 一 个 机 架 上 ， 这 样 从 效率 和 可 靠 性 上 ， 都 是 
最 优 的 (这 个 Google 公布 的 文档 中 有 专门 的 证 明 ， 有 兴趣 的 可 参阅 一 下 )。 如 果 考 虑 跨 数据 
中 心 ， 可 将 两 份 存在 一 个 数据 中 心 的 不 同 机 架 上 ， 另 一 份 放 到 另 一 个 数据 中 心 。 

3) 题目 4 涉及 BigTable 的 模型 。 主 要 思想 是 将 随机 写 转化 为 顺序 写 ， 进 而 大 大 提高 写 速 
度 。 具体 是 : 由 于 磁盘 物理 结构 的 独特 设计 ， 其 并 发 的 随机 写 〈 主 要 是 因为 磁盘 寻 道 时 间 长 ) 
非常 慢 , 考虑 到 这 一 点 , 在 BigTable 模型 中 , 首先 会 将 并 发 写 的 大 批 数据 放 到 一 个 内 存 表 ( 称 
为 “memtable”) 中 ， 当 该 表 大 到 一 定 程度 后 ， 会 顺序 写 到 一 个 磁盘 表 ( 称 为 “SSTable”) 中 ， 
这 种 写 是 顺序 写 ， 效 率 极 高 。 此 时 可 能 有 读者 问 ， 随 机 读 可 不 可 以 这 样 优化 ? 答案 是 : 看 情 
况 。 通 常 而 言 ， 如 果 读 并 发 度 不 高 ， 则 不 可 以 这 么 做 ， 因 为 如 果 将 多 个 读 重 新 排列 组 合 后 再 
执行 ， 系 统 的 响应 时 间 太 慢 ， 用 户 可 能 接受 不 了 ， 而 如 果 读 并 发 度 极 高 ， 也 许可 以 采用 类 似 
机 制 。 


如 何 解决 求职 中 的 时 间 冲 突 问题 ? 


对 于 求职 者 而 言 ， 求 职 季 就 是 一 个 赶场 季 ， 一 天 少 则 几 家 、 十 几 家 企业 入 校 招 聘 ， 多 则 
几 十 家 、 上 百 家 企 业 招 兵 买 马 ， 企 业 多 ， 选 择 项 自然 也 多 ， 这 冉 然 是 一 件 好 事情 ， 但 由 于 招 
聘 企业 实在 是 太 多 ， 自 然而 然 会 导致 另外 一 个 问题 的 发 生 : 同一 天 企业 扎堆 ， 且 都 是 自己 心 
仪 或 欣赏 的 大 牛 企业 的 现象 。 如 果 不 能 够 提前 掌握 企业 的 宣讲 时 间 、 地 点 ， 是 很 容易 迟到 或 
错过 的 。 但 有 时 候 即 使 掌握 了 宣讲 时 间 、 笔 试 和 面试 时 间 ， 还 是 有 可 能 错过 ， 为 什么 呢 ? 时 
间 冲 突 ， 人 不 可 能 具有 分 身 术 ， 也 不 可 能 同一 时 间 做 两 件 不 同 的 事情 ， 所 以 ， 很 多 时 候 就 必 
须 有 所 取舍 了 。 

到 底 该 如 何 取舍 呢 ?” 该 如 何 应 对 这 种 时 间 冲 突 的 问题 昵 ? 在 此 ， 编 者 将 自己 的 一 些 想 法 
和 经 验 分 享 出 来 ， 以 供 读 者 参考 : 

1) 如果 多 家 心仪 企业 的 校园 宣讲 时 间 发 生 冲 突 〈 前 提 是 只 宣讲 ， 不 笔试 ， 否 则 请 看 后 面 的 
建议 )， 此 时 最 好 的 解决 方法 是 和 同学 或 朋友 商量 好 ， 各 去 一 家 ， 然 后 大 家 进行 信息 共享 。 

2) 如 果 多 家 心仪 企业 的 笔试 时 间 发 生 冲 突 ， 此 时 只 能 选择 其 一 ， 毕 竞 企 业 的 笔试 时 间 都 
是 考虑 到 了 成 百 上 干 人 的 安排 ,需要 提前 安排 考场 、 考 务 人 员 和 阅卷 人 员 等 ， 不 可 能 为 了 某 
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一 个 人 而 轻易 改变 。 所 以 ， 最 好 选择 自己 更 有 兴趣 的 企业 参加 笔试 。 

3) 如 果 多 家 心仪 企业 的 面试 时 间 发 生 冲 突 ， 不 要 轻易 放弃 。 对 于 面试 官 而 言 ， 面 试 任何 
人 都 是 一 样 的 ， 因 为 面试 官 谁 都 不 认识 ， 而 面试 时 间 也 是 灵活 性 比较 大 的 ， 一 般 可 以 通过 电 
话 协商 。 求 职 者 可 以 与 相关 工作 人 员 《一般 是 企业 的 HR ) 进行 沟通 ， 以 某 种 理由 《例如 学 校 的 
事宜 、 导 师 的 事宜 或 家 庭 的 事宜 等 ， 前 提 是 必须 能 够 说 服 人 ， 不 要 给 出 的 理由 连 自己 都 说 服 不 
了 ) 让 其 调整 时 间 ， 一 般 都 能 协调 下 来 。 但 为 了 保证 协调 的 成 功率 ， 一 般 要 接 到 面试 通知 后 第 
一 时 间 联 系 相关 工作 人 员 变 更 时 间 ， 这 样 他 们 协调 起 来 也 更 方便 。 
正如 世界 上 没有 能 够 包 治 百 病 的 药物 一 样 ， 以 上 这 些 建 议 在 应 用 时 ， 很 多 情况 下 也 做 不 
到 全 盘 兼 顾 ， 当 必须 进行 多 选 一 的 时 候 ， 求 职 者 就 要 对 此 进行 评估 了 ,评估 的 项 目 可 以 包括 : 
对 企业 的 中 意 程 度 、 获 得 offer 的 概率 及 去 工作 的 可 能 性 等 。 评 估 的 结果 往往 具有 很 强 的 参考 
性 ， 求 职 者 依据 评估 结果 做 出 的 选择 一 般 也 会 比较 合理 。 


5 和 如 果 面试 问题 曾经 遇见 过 ， 是 否 要 告 
知 面 试 官 ? 
其 实 面试 中 ， 大 多 数 题目 都 不 是 凭空 想象 出 来 的 ， 而 是 有 章 可 循 ， 只 要 求职 者 肯 花 时 间 ， 


耐 得 住 秽 宽 ， 复 习 得 当 ， 基 本 上 在 面试 前 都 会 见 过 相同 的 或 者 类 似 的 问题 (当然 ， 很 多 知名 
企业 每 年 都 会 推陈出新 ， 这 些 题目 是 很 难 完全 复习 到 位 的 )。 所 以 ， 在 面试 中 ， 求 职 者 曾经 遇 


也 


二 


见 过 面试 官 提出 的 问题 也 就 不 足 为 奇 了 。 那 么 ， 一 旦 出 现 这 种 情况 ， 求 职 者 是 否 要 如 实 告诉 
面试 官 呢 ? 


选择 不 告诉 面试 官 的 理由 比较 充分 : 首先 ， 面 试 的 题目 60% 一 70% 都 是 陈 谷子 烂 芝 及 ， 
见 过 或 者 见 过 类 似 的 不 足 为 奇 ， 难 道 要 一 一 告知 面试 官 吗 ? 如 果 那 样 的 话 ， 估 计 就 没有 几 个 
题 不 用 告知 面试 官 了 ， 面 试 官 估计 也 就 要 等 着 失业 了 。 其 次 ， 即 使 曾经 见 过 该 问题 了 ， 也 是 
自己 辛勤 耕 耕 、 努 力 奋 斗 的 结果 ， 很 多 人 复习 不 用 功 或 者 方法 不 到 位 ， 也 许 从 来 就 没 见 过 ， 
而 这 些 题 也 许 正好 是 拉 开 求职 者 差距 的 分 水 岭 ， 是 面试 官 用 来 区 分 求职 者 实力 的 内 容 ， 为 什 
么 要 告知 面试 官 呢 ? 偷偷 的 一 个 人 乐 不 好 吗 ? 最 后 ， 一 旦 告知 面试 官 ， 面 试 官 很 有 可 能 会 不 
断 地 加 大 面试 题 的 难度 来 “为 难 ” 你 ， 对 你 的 面试 可 能 没有 半点 好 处 。 

同样 ， 选 择 告诉 面试 官 的 理由 也 比较 充分 : 第 一 ， 如 实 告诉 面试 官 ， 不 仅 可 以 彰显 出 求 
职 者 个 人 的 诚实 品德 ， 还 可 以 给 面试 官 留 下 良好 的 印象 ， 说 不 定 能 够 在 面试 中 加 分 。 第 二 ， 
有 些 问题 ， 即 使 求职 者 曾经 复习 过 ， 但 也 无 法 保证 完全 回答 正确 ， 如 果 向 面试 官 如 实 相 告 ， 
没准 还 可 以 规避 这 一 问题 ， 避 免 错 误 的 发 生 。 第 三 ， 求 职 者 如 果 见 过 该 问题 ， 也 能 轻松 应 答 ， 
题目 简单 倒 也 无 所 谓 ， 一 旦 题目 难度 比较 大 ， 求 职 者 却 对 面试 官 有 所 隐瞒 ， 就 极 有 可 能 给 面 
试 官 造 成 一 种 求职 者 水 平 很 强 的 假象 ， 进 而 导致 面试 官 的 判断 出 现 偏差 ， 后 续 的 面试 有 可 能 
向 着 不 利于 求职 者 的 方向 发 展 。 
其 实 ， 仁 者 见 仁 ， 智 者 见 智 ， 这 个 问题 并 没有 固定 的 答案 ， 需 要 根据 实际 情况 来 决定 。 
针对 此 问题 ， 一 般 而 言 ， 如 果 面 试 官 不 主动 询问 求职 者 ， 求 职 者 也 不 用 主动 告知 面试 官 真 相 。 
但 如 果 求 职 者 觉得 告知 面试 官 真相 对 自己 更 有 利 的 时 候 ， 也 可 以 主动 告知 。 
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2 及 在 被 企业 拒绝 后 是 否 可 以 再 申请 ? 


很 多 企业 为 了 能 够 在 一 年 一 度 的 招聘 季节 中 ， 提 前 将 优秀 的 程序 员 锁 定 到 自己 的 魔 下 ， 
往往 会 先 下 手 为 强 。 他 们 通常 采取 的 措施 有 以 下 两 种 : 第 一 种 ， 招 聘 实 习 生 ， 第 二 种 ， 多 轮 


招聘 。 


招聘 开始 后 ， 往 往 是 几 家 欢喜 儿 家 悉 ， 提 前 拿 到 企业 绿卡 的 ， 于 是 对 酒 当 歌 、 欢 天 喜 地 ， 


而 没有 被 选 上 的 ， 担 心 从 此 与 这 家 企业 无 缘 了 ， 于 是 整 日 回 字 写 在 脸 上 ， 忧 心 虱 虱 ， 感 叹 生 


不 适时。 难道 一 次 失望 的 表现 就 永远 会 被 企业 拉 入 黑 名单 了 吗 ? 难道 一 次 失败 的 经 历 就 会 永 


远 被 记录 在 个 人 历史 的 耻辱 柱 上 了 吗 ? 


答案 当然 是 否定 的 ， 对 心仪 的 女孩 表白 ， 即 使 第 一 次 被 拒绝 了 ， 都 还 可 以 一 而 再 再 而 三 
地 表白 呢 ? 多 次 表白 后 成 功 的 案例 比比 色 是 ， 更 何况 是 求职 找 工 作 。 一 般 而 言 ， 企 业 是 不 会 
记 仇 的 ， 尤 其 是 知名 的 大 企业 ， 对 此 都 会 有 明确 的 表示 。 如 果 在 企业 的 实习 生 招 聘 或 在 企业 
以 前 的 招聘 中 不 笠 被 pass 掉 了 ， 一 般 是 不 会 被 拉 入 企业 的 黑 名 单 的 。 在 下 一 次 招聘 中 ， 和 其 


他 求职 者 ， 具 有 相同 的 竞争 机 会 《有 些 企业 可 


能 会 要 求 求职 者 等 待 半年 到 一 年 时 间 再 能 应 聘 


该 企业 ， 但 上 一 次 求职 的 糟糕 表现 不 会 被 计 入 此 次 招聘 中 )。 


对 心仪 的 对 象 表白 被 拒绝 了 


待 ， 也 许 真 的 是 拒绝 ， 但 无 论 出 于 什么 原 
此 ， 以 编者 身边 的 很 多 同学 和 朋友 为 例 ， 很 多 人 最 开始 被 一 家 企业 拒绝 了 ， 过 了 一 段 时 间 ， 
又 发 现 他 们 已 成 为 该 企业 的 员工 。 所 以 ， 即 使 被 企业 拒绝 了 也 不 是 什么 大 不 了 的 事情 ， 以 后 


， 不 是 一 样 还 可 以 4 


洒 续 表白 吗 ? 也 许 是 在 考验 ， 也 许 是 在 等 


因 ， 此 时 此 刻 都 不 要 对 自己 丧失 信心 。 工 作 也 是 如 


还 有 机 会 的 ， 有 志 者 自 有 生计 万 计 ， 无 志 者 只 感 干 难 万 难 ， 关 键 是 看 你 愿意 成 为 什么 样 的 


人 了 。 


如 何 应 对 自己 不 会 回答 的 问题 ? 


在 面试 的 过 程 中 ， 求 职 者 对 面试 官 提 台 


的 问题 并 不 是 每 个 问题 都 能 回答 上 来 ， 计 算 机 技 


术 博 大 精深 ， 很 少 有 人 能 对 计算 机 技术 的 各 个 分 文学 科 了 如 指 掌 ， 而 且 抛 开 技术 层面 的 问题 ， 
在 面试 那 种 紧张 的 环境 中 ， 回 答 不 上 来 的 情况 也 容易 出 现 。 面 试 的 过 程 是 一 个 和 面试 官 “ 斗 


智 斗 勇 ” 的 过 程 ， 遇 到 自己 不 会 回 


答 的 问题 时 ， 错 误 的 做 法 是 保持 沉默 或 者 支 文 吾 吾 、 不 懂 


装 懂 ， 硬 着 头皮 胡乱 说 一 通 ， 这 样 会 使 面试 气氛 很 尴 从 ， 很 难 再 往 下 继续 进行 。 
其 实 面试 遇 到 不 会 的 问题 是 一 件 很 正常 的 事情 , 没有 人 是 万 事 通 ， 即 使 对 自己 的 专业 有 相当 


的 研究 与 认识 ， 也 可 能 会 在 面试 


P 遇 到 感觉 没有 任何 印象 、 不 知道 如 何 回答 的 问题 。 在 面试 中 遇 
到 实在 不 懂 或 不 会 回答 的 问题 ， 正 确 的 办 法 是 本 着 实事 求 是 的 原则 ， 态 度 诚 有 时， 告诉 面试 官 不 知 
道 答案 。 例 如 ,“ 对 不 起 ， 不 好 意思 ， 这 个 问题 我 回答 不 出 来 ， 我 能 向 您 请 教 吗 ?” 

征求 面试 官 的 意见 时 可 以 说 说 自己 的 个 人 想法 ， 如 果 面 试 官 同意 昕 了 ， 就 将 自己 的 想法 


说 出 来 ， 回 答 时 要 谦 进 有 礼 ， 切 不 可 说 起 没完 。 然 后 应 该 虚心 地 向 面试 官 请 教 ， 表 现 出 强烈 


的 学 习 欲 望 。 


所 以 ， 遇 到 自己 不 会 的 问题 时 ， 正 确 的 做 法 是 :“ 知 之 为 知之 ， 不 知 为 不 知 ” 不 懂 就 是 


Java 程序 员 醒 试 笔试 真题 尼 


不 懂 ， 不 会 就 是 不 会 ， 一 定 要 实事 求 是 ， 坦 然 面 对 。 最 后 也 能 给 面试 官 留 下 诚实 、 坦 率 的 好 
印象 。 


“ 激 将 法 ”是 面试 官 用 以 淘汰 求职 者 的 一 种 惯用 方法 ， 它 是 指 面试 官 采用 怀疑 、 尖 锐 或 吊 
吓 双人 的 交流 方式 来 对 求职 者 进行 提问 的 方法 。 例 如 ,“ 我 觉得 你 比较 缺乏 工作 经 验 ”“ 我 们 
需要 活泼 开朗 的 人 , 你 恐怕 不 合适 ”“ 你 的 教育 背景 与 我 们 的 需求 不 太 适 合 ”“ 你 的 成 绩 太 差 ” 
“你 的 英语 没 过 六 级 ”“ 你 的 专业 和 我 们 不 对 口 ”“ 为 什么 你 还 没 找到 工作 ”或 “你 竟然 有 好 多 
门 课 不 及 格 ” 等 ， 很 多 求职 者 遇 到 这 样 的 问题 ， 会 很 快 产生 我 是 来 面试 而 不 是 来 受 侮辱 的 想 
法 ， 往 往 会 被 “激怒 ” 于 是 奋起 反抗 。 干 万 要 记 住 ， 面 试 的 目的 是 要 获得 工作 ， 而 不 是 要 与 
面试 官 争 个 高 低 ， 也 许 争辩 取胜 了 ， 却 失去 了 一 份 工作 。 所 以 对 于 此 类 问题 求职 者 应 该 进行 
巧妙 的 回答 ， 一 方面 化 解 不 友好 的 气氛 ， 男 一 方面 得 到 面试 官 的 认可 。 
具体 而 言 ， 受 到 这 种 “ 激 将 ”时 ， 求 职 者 首先 应 该 保持 清醒 的 头脑 ， 企 业 让 你 来 参加 面 
试 ， 说 明 你 已 经 通过 了 他 们 第 一 轮 的 筛选 ， 至 少 从 简历 上 看 ， 已 经 表明 你 符合 求职 岗位 的 需 
要 ， 企 业 对 你 还 是 感 兴趣 的 。 其 次 ， 做 到 不 卑 不 亢 ， 不 要 被 面试 官 的 思路 带 走 ， 要 时 刻 保 持 
自己 的 思路 和 步调 。 此 时 可 以 换 一 种 方式 ， 如 介绍 自己 的 经 历 、 工 作 和 优势 ， 来 表现 自己 的 
抗 压 能 

针对 面试 官 提出 的 非 名 校 毕业 的 问题 ， 比 较 巧 妙 的 回答 是 : 比尔 盖 茨 也 并 非 毕业 于 哈佛 
大 学 ， 但 他 一 样 成 为 了 世界 首富 ， 成 为 举世 瞩目 的 人 物 。 针 对 缺乏 工作 经 验 的 问题 ， 可 以 回 
答 : 每 个 人 都 是 从 没 经验 变 为 有 经 验 的 ， 如 果 有 广 最 终 能 够 成 为 贵 公司 的 一 员 ， 我 将 很 快 成 
为 一 个 经 验 丰 富 的 人 。 针 对 专业 不 对 口 的 问题 ， 可 以 回答 专业 人 才 难 得 ， 复 合 型 人 才 更 难 
得 ， 在 某 些 方面 ， 外 行 的 灵感 往往 超过 内 行 ， 他 们 一 般 没 有 思维 定 势 ， 没 有 条 条 框框 。 面 试 
官 还 可 能 提问 : 你 的 学 历 对 我 们 来 讲 太 高 了 。 此 时 也 可 以 很 巧妙 地 回答 : 今天 我 带 来 的 3 张 
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学 历 证 书 ， 您 可 以 从 中 挑选 一 张 您 认为 合适 的 ， 其 他 两 张 ， 您 就 不 用 管 了 。 针 对 性 格 内 向 的 
问题 ， 可 以 回答 : 内 向 的 人 往往 具有 专心 致 志 、 钢 而 不 舍 的 品质 ， 而 且 我 善于 倾听 ， 我 觉得 
应 该 把 发 言 机 会 更 多 地 留 给 别人 。 


面对面 试 官 的 “ 挑 克 ” 行 为 ， 如 果 求 职 者 回答 得 结 结巴 巴 ， 或 者 无 言 以 对 ， 抑 或 低 形 于 
色 、 据 理 力 争 ， 那 就 掉 进 了 对 方 所 设 的 陷阱 ， 所 以 当 求职 者 碰 到 此 种 情况 时 ， 最 重要 的 一 点 


就 是 保持 头脑 冷静 ， 不 要 过 分 较真 ， 以 一 颗 平淡 的 心 对 待 。 


i 人 如 何 处 理 与 面试 官 持 不 同 观 点 这 个 问题 ? 


在 面试 的 过 程 中 ， 求 职 者 所 持 有 的 观点 不 可 能 与 面试 官 一 模 一 样 ， 在 对 某 个 问题 的 看 法 
上 ， 很 有 可 能 两 个 人 相去 甚 远 。 当 与 面试 官 持 不 同 观点 时 ， 有 的 求职 者 自作 聪明 ， 立 马 就 反 
驭 面试 官 ， 例 如 ,“ 不 见得 吧 !”“ 我 看 未 必 ”“ 不 会 ”““ 完 全 不 是 这 么 回 事 !” 或 “这 样 的 说 法 
虽然 也 许 确实 不 像 面试 官 所 说 的 ， 但 是 太 过 直接 的 反驳 往往 会 导致 面 


未 必 全 对 ”等 ， 其 实 ， 


试 官 心理 的 不 悦 ， 最 终 的 结果 很 可 能 是 “ 遥 一 时 之 快 ， 失 一 份 工作 ”。 


就 算 与 面试 官 持 不 一 样 的 观点 ， 也 应 该 委婉 地 表达 自己 的 真实 想法 ， 因 为 我 们 不 清楚 面 


试 官 的 度量 ， 碰 到 心胸 宽广 的 面试 官 还 好 ， 万 一 磁 到 了 “小 心眼 ”的 面试 官 ， 他 和 你 较真 起 


来 ， 吃 亏 的 还 是 自己 。 


所 以 回答 此 类 问题 的 最 好 方法 往往 是 应 该 先 赞 同 面试 官 的 观点 ， 给 对 方 一 个 台阶 下 ， 然 
后 再 说 明 站 己 的 观点 ， 用 三 同 奈 2 “而 且 ” 过 渡 ， 千 万 不 要 说 “但 是 ”， 日 说 了 6 日 是 ” “ 却 ” 


就 容易 把 自己 放 在 面试 官 的 对 立 面 去 。 


tik 什么 是 职场 暗语 ? 


随 着 求职 大 势 的 变迁 发 展 ， 以 往常 规 的 面试 套路 ， 因 为 过 于 单调 、 简 明 ， 已 经 被 众多 “ 面 
试 达 人 ” 们 挖掘 出 了 各 种 “破解 秘诀 ”， 形成 了 类 似 “ 求 职 宝 典 ” 的 各 类 “ 面 经 ”>。 所 谓 “ 道 
高 一 尺 ， 魔 高 一 丈 ”， 面 试 官 们 也 纷纷 升级 面试 模式 ， 为 求职 者 们 制作 了 更 为 隐蔽 、 间 接 、 含 


混 “ 下 套 ” 的 面试 题 


日 ， 


让 那些 早已 流传 开 来 的 “面试 攻略 ” 毫 无 用 武之 地 ， 一 此 蕴涵 丰富 
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信息 但 以 更 新 面目 出 现 的 问 话 屡 展 “秒杀 ”求职 者 ， 让 求职 者 一 头 雾 水 ， 掉 进 了 陷阱 里 面 还 
以 为 吃 到 肉 了 ， 例如,“ 面试 官 从 头 到 尾 都 表现 出 对 我 很 感 兴趣 的 样子 ， 营 造 出 马上 就 要 录用 


我 的 氛围 ， 为 什么 我 最 后 还 是 悲剧 了 ? ”“ 为 什么 HR 会 问 我 一 些 与 专业 、 能 力 根本 无 关 的 怪 


问题 ， 我 感觉 回答 得 也 还 行 ， 为 什么 最 后 还 是 被 拒 了 ? ”其 实 , 这 都 是 没有 听 懂 面试 “暗语 ”， 


没有 听 出 面试 官 “ 弦 外 之 音 ” 的 表现 。“ 瞳 语 ” 已 经 成 为 一 种 测试 求职 


心理 素质 、 挖 掘 求职 


者 内 心 真实 想法 的 有 效 手段 。 理 解 这 些 面试 中 的 瞳 语 ， 对 于 求职 者 而 言 ， 不 可 或 缺 。 


以 下 是 一 些 常 见 的 面试 暗语 ， 求 职 者 一 定 要 和 弄 清楚 其 中 列 含 的 深意 ， 不 然 可 能 “ 躺 着 也 


中 枪 ”， 最 后 上 只 能 儿 羽 而 归 。 
(1) 请 把 简历 先 放 在 这 ， 有 消息 我 们 会 通知 你 的 


面试 官 说 出 这 句 话 ， 则 表明 他 对 你 已 经 “兴趣 不 大 ” 为 什么 一 定 要 等 到 有 消息 了 再 通知 


呢 ? 难道 现在 不 可 以 吗 ? 所 以 ， 作 为 求职 者 ， 此 时 一 定 不 要 自作 聪明 、 
们 有 消息 通知 你 ， 因 为 他 们 一 般 不 会 有 消息 了 。 
(2) 我 不 是 人 力 资源 的 ， 你 别 拘束 ， 咱 们 就 当 是 聊天 ， 随 便 聊 聊 


一 般 来 说 ， 能 当面 试 官 的 人 都 是 久 经 沙场 的 老将 ， 都 不 太 好 对 付 。 表 面 上 彬 彬 有 礼 ， 看 


一 厢 情 愿 地 等 待 着 他 


上 去 笑 哑 虑 、 很 和 气 的 样子 ， 说 起 话 来 可 能 偶尔 还 带 点 小 结巴 ， 但 没准 


LE 儿 一 肚子 “ 坏 水 与 巴 


不 得 下 个 套 把 你 套 进去 。 所 以 ， 作 为 求职 者 ， 干 万 不 能 被 眼前 的 这 种 


“假象 ”所 迷惑 ， 而 应 


该 时 刻 保持 高 度 警觉 ， 面 试 官 不 经 意 间 问 出 来 的 问题 ， 看 似 随意 ， 很 可 能 是 他 最 想 知 道 的 。 


所 以 干 万 不 要 把 面试 过 程 当 作 聊天 ， 当 作 朋 友之 间 的 假 大 山 ， 不 要 把 面试 官 提出 的 问题 当 作 


是 普通 问题 ， 而 应 该 对 每 一 个 问题 都 仔细 思考 ， 认 真 回答 ， 心 理 上 Hol 
的 随意 接 话 和 回答 。 
(3) 是 否 可 以 谈 谈 你 的 要 求 和 打算 


d 住 ,切忌 不 经 过 大 脑 


面试 官 在 翻阅 了 求职 者 的 简历 后 ， 说 出 这 句 话 ， 很 有 可 能 是 对 求职 者 有 兴趣 ， 此 时 求职 


者 应 该 尽量 全 方位 地 表现 个 人 水 平 与 才能 ， 但 也 不 能 像 王 婆 卖 瓜 那样 


| 起 对 方 的 反感 。 


如 果 面 试 时 只 是 “例行公事 ” 式 的 问答 ， 没 有 什么 激情 或 者 主观 性 的 赞许 ， 此 时 希望 就 
很 渺 落 了 。 但 如果 面 试 官 对 你 的 专长 问 得 很 细 ， 而 且 表 现 出 一 种 极 大 的 关注 与 热情 ， 那 么 此 


时 希望 会 很 大 ， 作 为 求职 者 ， 一 定 要 抓 住 机 会 ， 将 自己 最 好 的 一 面 展示 在 面试 官 面 前 。 


(5) 你 好 ， 请 坐 


简单 的 一 名 话 ， 从 面试 官 口中 说 出 来 其 含义 就 大 不 同 了 。 一 般 而 言 ， 面 试 官 说 出 此 话 ， 


求职 者 回答 “你 好 ”或 “您 好 ”不 重要 ， 重 要 的 是 求职 者 是 否 “礼貌 回应 ”和 “ 华 不 坐 ”。 有 


的 求职 者 的 回应 是 “你 好 ”或 “您 好 ”后 直接 落座 ， 也 有 求职 者 回答 


“你 好 ， 谢 谢 ” 或 “您 


好 ， 谢 谢 ” 后 落座 ， 还 有 求职 者 一 声 不 哎 就 坐 下 去 ， 极 个 别 求职 者 回答 “谢谢 ”但 不 坐 下 来 。 
前 两 种 方法 都 可 接受 ， 后 两 者 都 不 可 接受 。 通 过 问候 语 ， 可 以 体现 一 个 人 的 基本 修养 ， 直 接 


影响 在 面试 官 心 目 中 的 第 一 印象 。 
(6) 面试 官 向 求职 者 探 过 号 去 


在 面试 的 过 程 中 ， 面 试 官 会 有 一 些 肢体 语言 ， 了 解 这 些 胶体 语言 对 于 了 解 面试 官 的 心理 


情况 以 及 面试 的 进展 情况 非常 重要 。 例 如 当面 试 官 向 求职 者 探 过 身 去 时 ， 一 般 表明 面试 官 对 
求职 者 很 感 兴趣 ， 当 面试 官 打 呵 从 或 者 目光 有 呆滞、 游 移 不 定 ， 甚 至 打开 手机 看 时 间或 打 电 话 、 
接 电话 时 ， 一 般 表 明 面 试 官 此 时 有 了 厌烦 的 情绪 ， 而 当面 试 官 收拾 文件 或 从 椅子 上 站 起 来 ， 
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一 般 表 明 此 时 面试 官 打 算 结束 面试 。 针 对 面试 官 的 胶体 语言 ， 求 职 者 也 应 该 迎合 他 们 :当面 
试 官 很 感 兴趣 时 ， 应 该 继续 陈述 自己 的 观点 ， 当 面试 官 大 烦 时 ， 此 时 最 好 停 下 来 ， 询 问 面试 
官 是 否 愿 意 再 继续 听 下 去 ， 当 面试 官 打算 结束 面试 ， 领 会 其 用 意 ， 并 准备 好 收场 白 ， 尽 快 地 
结束 面试 。 
(7) 你 从 哪里 知道 我 们 的 招聘 信息 的 
面试 官 提出 这 种 问题 ， 一 方面 是 在 评估 招聘 渠道 的 有 效 性 ， 另 一 方面 是 想 知道 求职 者 是 
否 有 熟人 介绍 。 一 般 而 言 ， 熟 人 介绍 总 体 上 会 有 加 分 ,“ 不 看 僧 面 看 佛 而 ”， 但 是 也 不 全 是 如 
此 。 如 果 是 一 个 在 单位 里 表现 不 佳 或 者 其 推荐 的 历史 记录 不 良 的 熟人 介绍 ， 则 会 起 到 相反 的 
效果 。 而 大 多 数 面 试 官 主要 是 为 了 评估 自己 企业 发 布 招聘 广 告 的 有 效 性 ， 顺 带 评 佑 HR 敬业 
与 否 。 

(8) 你 念书 的 时 间 还 是 比较 富足 的 
表面 上 看 ， 这 是 对 他 人 的 高 学 历 表示 赞赏 ， 但 同时 也 是 一 语 双关 ， 如 果 “ 高 学 历 ” 的 同 
时 还 搭配 上 一 个 “高 年 龄 ” 就 一 定 要 提防 面试 官 的 质疑 : 比如 有 些 人 因为 上 学 晚 或 者 工作 了 
以 后 再 回来 读 的 研究 生 ， 毕 业 年 龄 明显 高 出 平均 年 龄 。 此 时 一 定 要 向 面试 官 解释 清楚 ， 否 则 ， 
面试 官 如 果 自 己 揣摩 的 话 ， 往 往 会 向 不 利于 求职 者 的 方向 思考 ， 例 如 求职 者 年 龄 大 的 原因 是 
高 考 复读 过 、 考 研 用 了 两 年 甚至 更 长 时 间或 者 是 先 工 作 后 读 研 等 ， 如 果 面 试 官 有 了 这 种 想法 ， 
最 终 的 求职 结果 也 就 很 难说 了 。 

(9) 你 有 男 / 女 朋友 吗 ? 对 异地 恋爱 怎么 看 待 

一 般 而 言 ， 面 试 官 都 会 询问 求职 者 的 婚恋 状况 ， 一 方面 是 对 求职 者 个 人 问题 的 关心 ， 另 
一 方面 ， 对 于 女性 而 言 ， 绝 大 多 数 面试 官 不 是 看 中 求职 者 的 美貌 性 感 、 温 柔 贤 囊 ， 特 意 来 刺 
探 你 的 隐私 ， 他 提出 是 否 有 男 朋友 的 问题 ， 很 有 可 能 是 在 试探 你 是 否 近期 要 结婚 生子 ， 将 会 
给 企业 带 来 什么 程度 的 负担 。“ 能 不 能 接受 异地 恋 ”， 很 有 可 能 是 考察 你 是 否 能 够 安心 在 一 个 
地 方 工作 , 或 者 是 暗示 该 岗位 可 能 需要 长 期 出 差 .试探 求职 者 如 何在 感情 和 工作 上 做 出 抉择 。 
与 此 类 似 的 问题 还 有 “如 果 求 职 者 已 婚 ， 面 试 官 会 问 是 否 生育 ， 如 果 已 育 可 能 还 会 问 小 孩 谁 
带 ? ”所 以 ， 如 果 面 试 官 有 这 一 层面 的 意思 ， 尽 量 要 当场 表态 ， 避 免 将 来 的 麻烦 。 

《10) 你 还 应 聘 过 其 他 什么 企业 

面试 官 提出 这 种 问题 是 在 考核 你 的 职业 生涯 规划 ， 同 时 顺便 评估 下 你 被 其 他 企业 录用 或 
淘汰 的 可 能 性 。 当 面试 官 对 求职 者 提出 此 种 问题 ， 表 明 面 试 官 对 求职 者 是 基本 肯定 的 ， 只 是 
还 不 能 下 决定 是 否 最 终 录用 。 如 果 你 还 应 聘 过 其 他 企业 ， 请 最 好 选择 相关 联 的 岗位 或 行业 回 
答 。 一 般 而 言 ， 如 果 应 聘 过 其 他 企业 ， 一 定 要 说 自己 拿 到 了 其 他 企业 的 offer， 如 果 其 他 的 行 
业 影 响 力 高 于 现在 面试 的 企业 ， 无 疑 可 以 加 大 你 自身 的 筹码 ， 有 时 甚至 可 以 因此 拿 到 该 企业 
的 顶级 offer， 如 果 行 业 影响 力 低 于 现在 面试 的 企业 ， 如 果 回 答 没 有 拿 到 offer， 则 会 给 面试 官 
一 种 误导 : 连 这 家 企业 都 没有 给 你 offer， 我 们 如 果 给 你 offer 了 ， 岂 不 是 说 明 我 们 不 如 这 家 
企业 。 

(11) 这 是 我 的 名 片 ， 你 随时 可 以 联系 我 
在 面试 结束 ， 面 试 官 起 身 将 求职 者 送 到 门口 ， 并 主动 与 求职 者 握手 ， 提 供给 求职 者 名 片 
或 者 自己 的 个 人 电话 ， 和 希望 日 后 多 加 联系 ， 此 时 ， 求 职 者 一 定 要 明白 ， 面 试 官 已 经 对 自己 非 
常 肯 定 了 ， 这 是 被 录用 的 前 兆 ， 因 为 很 少 有 面试 官 会 放下 身段 ， 对 一 个 已 经 没有 录用 可 能 的 
求职 者 还 如 此 “厚爱 ”很 多 面试 官 在 整个 面试 过 程 中 会 一 直 塑 造 出 一 种 即将 录用 求职 者 的 假 
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象 ， 表 态 也 很 暧昧 ， 例 如 “你 来 到 我 们 公司 的 话 ， 有 可 能 会 比较 忙 ” 等 模棱两可 的 表述 ， 但 
如 果 面 试 官 亲 手 将 名 片 呈 交 ， 言 谈 中 也 流露 出 兴奋 、 积 极 的 意向 和 表情 ， 一 般 是 表明 了 一 种 
接纳 你 的 态度 。 

(12) 你 担任 职务 很 多 ， 时 间 安 排 得 过 来 吗 ? 

对 于 有 些 职位 ， 例 如 销售 等 ， 学 校 的 积极 分 子 往往 更 具 优 势 ， 但 在 应 聘 研发 类 岗位 时 ， 
却 并 不 一 定 吃 香 。 面 试 官 提出 此 类 问题 ， 其 实 就 是 对 一 些 在 学 校 当 “领导 ”的 学 生 的 一 种 反 


感 ， 大 量 的 社交 活动 很 有 
问题 ， 求 职 者 在 
己 的 专业 技能 。 


(13) 面试 结束 后 ， 面 试 


可 能 占据 学 业 时 间 ， 从 而 导致 专 } 


已 
已 


A 已 
领导 ; 


台 ， 如 果 有 比 你 更 好 的 就 


不 用 你 了 ， 没 有 的 话 会 找 你 ; 


重新 选择 ， 可 能 会 安 


至 少 这 一 次 不 能 给 予 肯定 


的 


聘 本 公司 ”的 话 ， 此 时 一 般 十 有 八 九 能 和 他 作 同 事 了 。 
(14) 我 们 会 在 几 天 后 联系 你 


"Ey 
已 


仔 纪 


说 上 


三 
| 


tH 这 人 句 话 ， 表 明了 面试 


对 求职 者 还 是 很 感 兴趣 的 ， 尤 其 是 当面 试 官 


此 基础 不 牢固 等 。 所 以 ， 针 对 上 述 
回答 时 ， 一 定 要 告诉 面试 官 ， 自 己 参与 组 织 的 “课外 活动 ”并 没有 影响 到 自 


说 “我 们 有 消息 会 通知 你 的 ” 

一 般 而 言 ， 面 试 官 让 求职 者 等 通知 ， 有 多 种 可 能 性 : 没戏 了 ; 给 你 理 
公司 对 你 不 是 特别 满意 ， 和 希望 再 多 面试 一 些 人 ， 把 你 当 作 备 
公司 需要 对 面试 过 并 留 下 来 的 人 进行 
排 二 次 面试 。 所 以 ， 当 面试 官 说 这 话 时 ， 表 明 此 时 成 功 的 可 能 性 不 大 ， 
回复 ， 相 反 如 果 对 方 热情 地 和 你 握手 言 别 ， 再 


试 的 人 不 是 负责 人 ， 


加 一 名 “欢迎 你 应 


已 


询问 你 所 能 接受 的 薪资 情况 等 相关 情况 后 ， 否 则 他 们 会 尽快 结束 面谈 ， 


(15) 面试 官 认 为 该 结束 面试 时 的 上 暗语 


一 般 而 言 ， 求 职 者 自 
试 官 先 会 把 工作 内 容 和 职 
方 会 谈 及 福利 待遇 问题 ， 
盲目 拖延 时 间 。 

面试 官 认 为 该 结束 面 


1) 我 很 感激 你 对 我 人 


我 介绍 之 后 


二 
责 介 


这 些 都 是 高 潮 话题 ， 谈 完 之 后 你 就 应 该 


试 时 ， 往 往 会 说 以 下 


] 公 司 这 项 工作 的 关注 。 


2) 真 难为 你 了 ， 跑 了 这 么 多 路 ， 多 谢 了 。 
3) 谢谢 你 对 我 们 招聘 工作 的 关心 ， 我 们 一 旦 做 出 决定 就 会 立即 通知 你 。 


4) 你 的 情况 我 们 已 经 了 解 。 你 知道 ， 在 做 出 最 后 决定 之 前 我 们 还 要 面试 儿 位 上 
微笑 ， 和 面试 官 握手 告辞 ， 并 | 


此 时 ， 求 职 者 应 该 主 


， 面 试 官 会 相应 地 提出 各 类 问题 ， 
绍 一 番 ， 接 着 让 求职 者 谈 谈 今 后 工作 的 打算 和 设想 ， 


举 


而 不 是 多 此 一 


然后 转向 谈 工作 。 鞠 
然后 ， 双 
告辞 的 姿态 ， 不 要 


动作 了 


潮 示 的 话语 来 提醒 求职 


请 人 。 


动 站 起 身 来 ， 露 出 


日 谢 谢 他 ， 然 后 有 


之 前 表现 出 浮躁 不 安 、 急 欲 离 去 


礼貌 地 退出 面试 室 。 适 时 离 场 还 包括 不 要 在 面试 官 结束 谈 训 
或 另 去 赴约 的 样子 ， 过 早 地 想 离 场 会 使 面试 官 


(16) 如 果 让 你 调 到 其 他 网 位， 你 愿意 吗 


有 些 企业 招收 岗位 和 
位 也 许 已 经 “ 人满为患 ” 
业 的 一 员 。 面 对 这 种 提问 
新 的 岗位 又 有 一 定 的 把 握 


人 员 较 多 ， 克 
或 “名 伦 有 3 
， 求 职 者 应 该 迅速 
， 也 可 以 先进 单位 


合 自己 ， 最 好 当面 回 
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答 不 行 。 


E 面 试 中 ， 当 听 到 面试 
E” 了 ， 但 企业 对 你 兴趣 不 减 ， 还 是 很 希望 你 能 


认为 你 应 聘 没 有 诚意 或 做 事情 没有 耐心 。 


EE 
已 


说 出 此 话 时 ， 言 外 之 意 是 该 岗 
成 为 企 


放出 反应 ， 如 果 认 为 对 方 是 个 不 错 的 企业 ， 你 对 
再 选 岗位 ， 如 果 对 方 情况 一 般 ， 新 岗位 又 不 太 适 


可 试 笔试 经 验 技 巧 篇 


(17) 你 能 来 实习 吗 

对 于 实习 这 种 敏感 的 问题 ， 面 试 官 一 般 是 不 会 轻易 提 及 的 ， 除 非 是 确实 对 求职 者 很 感 兴 
趣 ， 相 中 求职 者 了 。 当 求职 者 遇 到 这 种 情况 时 ， 一 定 要 清楚 面试 官 的 意图 ， 他 希望 求职 者 能 
够 表态 ， 如 果 确 实 可 以 去 实习 ， 一 定 及 时 地 在 面试 官 面 前 表达 出 来 ， 这 无 疑 可 以 给 予 自 己 更 
多 的 机 会 。 

(18) 你 什么 时 候 能 到 岗 

当面 试 官 问 及 到 岗 的 时 间 时 ， 表 明 面 试 官 已 经 同意 给 offer 了 ， 此 时 只 是 为 了 确定 求职 者 
是 和 否 能 够 及 时 到 岗 并 开始 工作 。 如 果 确 有 难题 千 万 不 要 遮 遮掩 手 ， 含 糊 其 酬 ， 说 清楚 情况 ， 
诚实 守信 。 

针对 面试 中 存在 的 这 种 暗语 ， 求 职 者 在 面试 过 程 中 ， 一 定 不 要 “很 傻 很 天 真 ” 要 多 留 一 
个 心眼 ， 多 推敲 面试 官 的 深意 ， 仔 细 想 想 其 中 的 “潜台词 ” 从 而 将 面试 官 的 那 点 “小 伎俩 ?” 
掌控 在 股 掌 之 中 。 


> 
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真题 篇 主要 列举 了 18 套 来 自 于 顶级 IT 企业 的 面试 笔试 真题 ， 这 些 企业 是 行 
业 的 标杆 ， 代 表 了 行业 的 最 高 水 准 ， 而 他 们 所 出 的 面试 笔试 真题 不 仅 难 易 适中 ， 
覆盖 面 广 (包括 语言 基础 、 链 表 、 算 法 和 海量 数据 处 理 等 内 容 )， 而 且 具 有 非常 好 
的 区 分 度 ， 代 表 性 非常 强 ， 是 历年 来 程序 员 面 试 笔试 中 的 必 考 项 或 常 考 项 ， 且 越 
来 越 多 的 中 小 企业 开始 从 中 摘 取 部 分 题目 或 者 直接 全 盘 照 搬 以 作为 面试 笔试 题 。 


ED 某 知名 互联 网 下 载 服务 提供 商 软件 工程 师 笔试 是 


» 


1 


2 


3. 


4. 


选择 题 
访问 修饰 符 作 用 范围 由 大 到 小 是 
A. private-protected-default-public 


C. private-default-protected-public 


bE 
B. public-protected-default-private 
D. public-default-protected-private 


A. java.util.List 
C. java.util.Collection 


以 下 不 是 Object 类 的 方法 的 是 ( 。”)。 


A. hashCode() 


C. notify() 
有 如 下 代码 : 


在 Java 语言 中 ， 下 面 接口 以 键 - 值 对 的 方式 存储 对 象 的 是 (  ”)。 


B. java.util.Map 
D. java.util.Set 


B. finalize() 
D. hasNext() 


public class Test 
{ 
public void change(String str, char ch[]) 
{ 
str = "test ok"; 
ch[0] = 
} 
public static void main(String args[]) 
{ 
String str = new String("good"); 
char[] ch= fa bc 
Test ex = new Test(); 
ex.change(str, ch); 
System.out.print(str + "and "); 
System.out.print(ch); 


} 


上 面 程序 的 运行 结果 是 (。”)。 


A. goodand abc 
C. test ok and abc 


二 、 填 空 题 


1. 
2， 


Math.round(12.5) 的 返回 值 等 于 ( 
有 如 下 程序 : 


B. good and gbc 
D. test ok and gbc 


)，Math.round(-12.5) 的 返回 值 等 于 ( )。 


String strl="hello world"; 
String str2="hello"+newString("world"); 
System.out.println (str1==str2); 
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日 


那么 程序 的 运行 结果 是 ( )。 
3. 在 Java 语言 中 ， 基 本 数据 类 型 包括 〈 


数值 类 型 (  )。 
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4. 字符 串 分 为 两 大 类 : 一 类 是 字符 串 常 量 ( ”); 男 一 类 是 字符 


三 、 简 答题 

1. 接口 和 抽象 类 有 什么 区 别 ? 
2. 实现 多 线程 的 方法 有 哪儿 种 ? 
3. 利用 递归 方法 求 6! 

4. 用 Java 语言 实现 一 个 观察 者 模式 。 


5. 一 个 有 10 亿 条 记录 的 文本 文件 ， 已 按照 关键 字 排 好 序 存 储 ， 请 设计 一 个 算法 ， 可 以 
从 文件 中 快速 查找 指定 关键 字 的 记录 。 


某 知名 社交 平台 软件 工程 师 笔试 题 


一 、 单 项 选择 题 


1. 二 进 制 数 11101 转化 为 十 进 制 数 是 


A. 23 B. 17 
2. 以 下 可 以 对 对 象 加 互 斥 锁 的 关键 字 是 
A. synchronized B. serialize 


二 、 不 定 项 选择 题 


C. 26 
( )。 


C. volatile 


1 下列 关 于 类 的 构造 方法 的 描述 中 ， 正 确 的 是 ( ” ”)。 


A. 类 中 的 构造 方法 不 可 省 略 


B， 构 造 方法 必须 与 类 同名 ， 但 方法 不 能 与 class 同名 
C. 构造 方法 在 一 个 对 象 被 new 时 执行 


D. 一 个 类 只 能 定义 一 个 构造 方法 


2. 下 列 关 于 Java 语言 中 main 方法 的 描述 中 ， 正 确 的 是 “〈 Ds 


A.， Java 程序 的 main 方法 必须 写 在 类 里 再 


B. Java 程序 中 可 以 有 多 个 main 方法 
C. Java 程序 的 main 方法 中 ， 如 果 只 有 一 条 语句 ， 可 以 不 用 大 括号 们 括 起 来 
D. Java 程序 中 类 名 必须 与 文件 名 一 样 

3. 在 类 声明 中 ， 声 明 一 个 类 不 能 再 被 继承 的 关键 字 是 » 


A. private B. abstract 
4. 下 面 关 于 关键 字 abstract 的 描述 中 ， 了 


C. final 
FE 确 的 是 汽 


A. 关键 字 abstract 可 以 修饰 类 或 方法 


B. final 类 的 方法 都 不 能 是 abstract， 

C. abstract 类 不 能 实例 化 

D. abstract 类 的 子 类 必须 实现 其 超 类 
5. 以 下 不 是 合法 标识 符 的 是 A 

A. STR B. x3ab 


因为 final 类 不 能 有 子 类 


的 所 有 abstract 方法 


C. void 


D. 


D. 


D. 


D. 
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static 


static 


abcd 


| 
4 
办 


6. 以 下 关于 类 的 描述 中 ， 正 确 的 是 ” )。 
A. 只 要 没有 定义 不 带 参 数 的 构造 方法 ，JVM 都 会 为 类 生成 一 个 默认 构造 方法 
B. 局 部 变量 的 作用 范围 仅仅 在 定义 它 的 方法 内 ， 或 者 是 在 定义 它 的 控制 流 块 中 
C. 使 用 其 他 类 的 方法 仅仅 需要 引用 方法 的 名 字 即 可 
D. 在 类 中 定义 的 变量 称 为 类 的 成 员 变 量 ， 在 其 他 类 中 可 以 直接 使 用 
7. 有 如 下 代码 : 


public class Test 
{ 
public static void main(String args[]) 
{ 
int i; 
i=6; 
System.out.print(i); 
System.out.print(i++); 
System.out.print(D); 
} 
} 
以 上 程序 的 运行 结果 是 ( 。”)。 
A. 666 B. 667 CGC, 677 D. 676 


8. 下 列 关 于 Java 语言 中 关键 字 super 的 说 法 中 ， 正 确 的 是 )。 
A. 关键 字 super 是 在 子 类 对 象 中 指 代 其 父 类 对 象 的 引用 
B. 子 类 通过 关键 字 super 只 能 调用 父 类 的 属性 ， 而 不 能 调用 父 类 的 方法 
C. 子 类 通过 关键 字 super 只 能 调用 父 类 的 方法 ， 而 不 能 调用 父 类 的 属性 
D. 关键 字 super 不 仅 可 以 指 代 子 类 的 直接 父 类 ， 还 可 以 指 代 父 类 的 父 类 
9. 下 面 关 于 String、StringBuilder 以 及 StringBuffer 的 描述 中 ， 正 确 的 是 六 
A. 对 String 对 象 的 任何 改变 都 不 影响 到 原 对 象 ， 相 关 的 任何 change 操作 都 会 生成 新 
的 对 象 
B.StringBuffer 是 线程 安全 的 
C. StringBuilder 是 线程 安全 的 
D. 可 以 修改 StringBuilder 和 StringBuffer 的 内 容 
10. 以 下 不 是 基本 数据 类 型 的 类 型 有 ( js 
A. int B. String C. Byte D. Float 
11. JavaThread 中 的 方法 resume0 负 责 恢复 哪些 线程 的 执行 ? ) 
A. 通过 调用 wait0 方 法 而 停止 运行 的 线程 
B. 通过 调用 sleep0 方 法 而 停止 运行 的 线程 
C. 通过 调用 stop0 方 法 而 停止 的 线程 
D. 通过 调用 suspend0 方 法 而 停止 运行 的 线程 
12. 有 如 下 代码 : 


public class Test 
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| public static int testException(int i)throws Exception 
{ 
try 
1 
return 1/5; 
} 
catch (Exception e) 
{ 
throw new Exception("exception in a aMethod"); 
} 
finally{ 
System.out.printf("finally"); 
} 
} 
public static void main(String[] args) 
{ 
try 
{ 
testException(0); 
} 
catch (Exception ex) 
| System.out.printf("exception in main"); 
} 
System.out.printf("finished"); 
} 
} 
以 上 这 段 代 码 编译 运行 后 ， 输 出 的 结果 是 ( 。”)。 
A. finallyexception in mainfinished B. finallyfinished 
C. exception in mainfinally D. finallyexception in mainfinished 
13. 释放 掉 一 个 指定 占据 的 内 存 空间 的 方法 是 ( ” )。 
A. 调用 system.gc0 方 法 B. 调用 free0 方 法 
C. 赋值 给 该 项 对 象 的 引用 为 null D. 程序 员 无 法 明确 强制 垃圾 回收 器 运行 
14. 以 下 关于 Spring 框架 的 描述 中 ， 正 确 的 是 )5 
A. Spring 是 “依赖 注入 ”模式 的 实现 
B. Spring 是 一 个 轻 量 级 Java EE 的 框架 集合 
C. 使 用 Spring 可 以 实现 声明 事务 
D. Spring 提供 了 AOP 方式 的 日 志 系统 
15. 堆 的 形状 是 一 棵 ( ”)。 
A. 完全 二 又 树 B. 平衡 二 又 树 
C. 二 又 排序 树 D. 满 二 又 树 
16. 下 列 关于 依赖 注入 的 描述 中 ， 正 确 的 是 (  )。 
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A. 依赖 注入 提供 使 用 接口 编程 

B. 依赖 注入 使 组 件 之 间 相 互 依赖 ， 相 互 制约 

C. 依赖 注入 能 够 独立 开发 各 组 件 ， 然 后 根据 组 件 间 关 系 进行 组 装 

D. 依赖 注入 指 对象 在 使 用 时 动态 注入 
17. 以 下 关于 HashMap 与 HashTable 的 说 法 中 ， 正 确 的 是 〈 )。 

A. 友 代 HashMap 采用 快速 失败 机 制 ， 而 HashTable 不 是 

B. HashTable 允许 null 值 作为 key 和 value， 而 HashMap 不 可 以 

C. HashMap 不 是 同步 的 ， 而 HashTable 是 同步 的 

D. 两 者 都 是 用 key-value 方式 获取 数据 
18. list 是 一 个 ArrayList 的 对 象 ， 当 将 选项 〈 ) 的 代码 填 到 /Mtodo delete 处 时 ， 可 以 

在 Iterator 遍历 的 过 程 中 正确 并 安全 地 删除 一 个 list 中 保存 的 对 象 。 


Iterator it = list.iterator(); 


int index = 0; 
while (it.hasNext()) 
{ 
Object obj = it.next(); 
让 (needDelete(obj)) /needDelete 返回 boolean， 决 定 是 否 要 删除 
{ 
//todo delete 


} 


index++; 


} 


A. it.remove() B. list.remove(index) 
C. list.remove(ob]j) D. list.delete(index) 
19. 以 下 属于 算法 结构 的 是 (  )。 
A. 输入 数据 B. 处 理 数据 C. 输出 结果 D. 存储 数据 
20. 己 知 某 二 又 树 的 后 序 遍 历 序列 是 dabec， 中 序 人 遍历 序列 是 debac， 那 么 它 的 前 序 遍 历 
序列 是 (  )。 


A. abcde B. dceab C. deabc D. cedba 
21. 算法 的 空间 复杂 度 是 指 (  ”)。 
A. 算法 程序 的 长 度 B. 算法 程序 中 的 指令 条 数 
C. 算法 程序 所 占 的 存储 空间 D. 算法 执行 过 程 中 所 需要 的 存储 空间 


22. 二 又 树 是 非 线 性 数据 结构 ， 以 下 关于 其 存储 结构 的 描述 中 ， 正 确 的 是 《〈 js 
A. 它 不 能 用 链 式 存储 结构 存储 
B. 它 不 能 用 顺序 存储 结构 存储 
C. 顺序 存储 结构 和 链 式 存储 结构 都 不 能 使 用 
D. 顺序 存储 结构 和 链 式 存 储 结构 都 能 存储 
23. 在 一 棵 二 叉 树 上 ， 第 4 层 的 结 点 数 最 多 是 〈 )。 
A. 8 B. 16 C. 32 D. 64 
24. 设 一 组 初始 记录 关键 字 序列 (5，2，6，3，8)， 以 第 一 个 记录 关键 字 5 为 基准 进行 
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一 趟 快速 排序 的 结果 为 《  )。 


的 后 面 插 入 结 
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A. 3, 2, 5, 8, 6 
C. 3, 2, 5, 6, 8 


事务 隔离 级 别 是 由 (  ”) 实现 的 。 


A. Hibernate 
C. 数据 库 系统 


D. 


B. 


D. 


23 3， 5, 8， 6 
2, 3, 6, 5, 8 


Java 应 用 程序 
JDBC 驱动 程序 


26. 设 指针 变量 p 指向 双向 链表 中 结 点 A, 指针 变量 s 指向 被 插入 的 结 点 X, 则 在 结 点 A 


点 的 操作 序列 为 《 


A. s->left=p;s->right=p->right;p->right=s;p->right->left=s 
B. s->left=p;s->right=p->right;p->right->left=s;p->right=s 
C. p->right=s;s->left=p;p->right->left=s;s->right=p->right 
D. p->right=s;p->right->left=s;s->left=p;s->right=p->right 


27. 在 排序 方法 中 ， 从 未 排序 序列 中 挑选 元 素 ， 并 将 其 依次 插入 己 排 序 序列 (初始 时 为 
) 的 一 端的 方法 ， 称 为 )。 
A. 归并 排序 B. 希 尔 排序 C. 插入 排序 D. 选择 排序 
28. 操作 系统 的 功能 是 进程 处 理 机 管理 、( ) 管理 、( ) 管理 、 文 件 管理 和 作业 
管理 等 。 
A. 设备 B. 存储 器 C. 硬件 D. 软件 
29. 下 列 中 断 属于 强迫 性 中 断 的 是 ( )。 
A. 掉 电 B. 设备 出 错 C. 时 间 片 到 时 DD. 执行 print 语句 
30. 进程 调度 是 从 ) 选择 一 个 进程 投入 运行 。 
A. 就 绪 队 列 B. 作业 后 备 队 列 C. 等 待 队列 D. 提交 队列 
31.“ 死 锁 ” 是 针对 “《 ) 的 。 
A. 某 个 进程 申请 资源 数 超过 了 系统 拥有 的 最 大 资源 数 
B. 某 个 进程 申请 系统 中 不 存在 的 资源 
C. 硬件 故障 
D. 多 个 并 发 进程 竞争 独占 型 资源 
32. 某 系 统 中 有 11 台 打 印 机 ，N 个 进程 共享 打印 机 资源 ， 每 个 进程 要 求 3 台 ， 当 NI 的 取 
值 不 超过 ) 时 ， 系 统 不 会 发 生死 锁 。 
A. 3 B. 5 C. 8 D. 7 
33. IP 协议 属于 ( )。 
A. 网 络 互 联 层 ”B. 应 用 层 C. 数据 链 路 层 ”DD. 传输 层 
34. 将 网 络 物理 地 址 转换 为 IP 地 址 的 协议 是 5 
A. 卫 B. ICMP C. ARP D. RARP 
35. 对 于 卫 地 址 130.63.160.2， 掩 码 为 2355.255.255.0， 子 网 号 为 《〈 疙 
A. 160.2 B. 160 C. 63.160 D. 63.160.2 
36. 对 于 卫 地址 200.5.6.4， 属 于 ( ) 类 地 址 。 
A. A B. B C.C D. D 
37. 一 个 广域网 和 一 个 局 域 网 相连 ， 需 要 的 设备 是 )。 
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A. NIC B. 网 关 C. 集线器 D. 路 由 器 
三 、 问 答题 
1. List<? extends T> 和 List<? super T> 之 间 有 什么 区 别 ? 
2. 给 出 两 种 单 例 模式 的 实现 方法 ， 并 说 明 这 两 种 方法 的 优 缺点 。 
3. 描述 Java 语言 中 抽象 基 类 和 接口 各 自主 要 的 使 用 场景 。 
4 
5 


.int 和 Integer 的 区 别 是 什么 ? 

. 已 知 两 个 链表 headl 和 head2 各 自 有 序 ， 请 把 它们 合并 成 一 个 依然 有 序 的 链表 。 结 果 
链表 要 包含 headl 和 head2 的 所 有 结 点 ， 即 结 点 值 相 同 。 

6. 给 定 a、b 两 个 文件 ， 各 存放 50 亿 个 url， 每 个 ut 各 占 64B， 内 存 限制 是 4GB， 请 找 
出 文件 a 与 文件 b 中 共同 的 url。 


ES 某 知名 安全 软件 服务 提供 商 软件 工程 师 笔试 是 


一 、 不 定 项 选择 题 
1. “hello”instanceof Object 的 返回 值 是 〈 Ys 
A. “abcd” B. true C. false D. String 
2. 下 面 有 关 方 法 覆盖 的 描述 中 ， 不 正确 的 是 (  ”)。 
A. 者 盖 的 方法 一 定 不 能 是 private 的 
B. 要 求 履 盖 和 被 覆盖 的 方法 必须 具有 相同 的 访问 权限 
C. 上 懂 盖 的 方法 不 能 比 被 履 盖 的 方法 抛 出 更 多 的 噶 负 
D. 要 求 履 盖 和 被 覆盖 的 方法 有 相同 的 名 字 、 参 数列 以 及 返回 值 
3. 下 面 说 法 正确 的 是 (  )。 
A. 如 果 源 代码 中 有 package 语句 ， 则 该 语句 必须 被 放 在 代码 的 第 一 行 〈 不 考虑 注释 
和 空格 ) 
B. 如 果 源 代码 中 有 main(0 方 法 ， 则 该 方法 必须 被 放 在 代码 的 第 一 行 
C. 如 果 源 代码 中 有 import 语句 ， 则 该 语句 必须 被 放 在 代码 的 第 一 行 〈 不 考虑 注释 和 
空格 ) 
D. 如 果 某 文件 的 源 代码 中 定义 了 一 个 public 的 接口 ， 则 接口 名 和 文件 名 可 以 不 同 
4. 下 面 变量 名 中 合法 的 有 (  ”)。 
A. 2var B. var2 C. var D. 1_ 
E. S$var F. #var 
5. 一 个 Java 程序 运行 从 上 到 下 的 环境 次 序 是 ( ” ”)。 
A. 了 及 EUJVM、 操 作 系统 、Java 程序 、 便 件 
B. Java 程序 、JRE/JVM、 硬 件 、 操 作 系 统 
C.Java 程序 、JRE/JVM、 操 作 系统 、 人 硬件 
D. Java 程序 、 操 作 系 统 、JRE/JVM、 硬 件 
6. 下 面 关 键 字 中 ， 可 以 用 来 修饰 接口 中 的 变量 的 是 (  ”)。 
A. static B. private C. synchronized D. protected 
7. 有 如 下 代码 : 
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String s="“xbcde’””; 
System.out.printIn(Ss.charA.t(4)); 


以 下 针对 上 述 代 码 段 的 描述 中 ， 正 确 的 是 ( )。 
A. 输出 字符 e 
B. 什么 都 没有 ， 抛 出 ArrayIndexOutOfBoundsException 
C. 输出 字符 d 
D. 代码 编译 不 成 功 ， 因 为 charA.t0 方 法 不 属于 String 类 
8. 下 面 创建 Map 集合 的 方式 中 ， 正 确 的 是 ( )s 
A. Map m=new Map(new Collection()) B. Map m=new Map(10, 2,40) 
C. Map m=new Map() D. Map 是 接口 ， 所 以 不 能 实例 化 
9. 以 下 关于 被 访问 控制 符 protected 修饰 的 成 员 变 量 的 描述 中 ， 正 确 的 是 )。 
A. 可 以 被 三 种 类 所 引用 : 该 类 自身 、 与 它 在 同一 个 包 中 的 其 他 类 、 在 其 他 包 中 的 该 
类 的 子 类 
B， 只 能 被 该 类 自身 所 访问 和 修改 
C. 可 以 被 两 种 类 访问 和 引用 : 该 类 本 身 、 该 类 的 所 有 子 类 
D. 只 能 被 同一 个 包 中 的 类 访问 
10. 为 了 区 分 类 中 重 载 的 同名 的 不 同方 法 , 要求 (  )。 
A. 采用 不 同 的 形式 参数 列表 B. 采用 不 同 的 返回 值 类 型 
C. 调用 时 用 类 名 或 者 对 象 名 作 前 绥 D. 采用 不 同 的 参数 名 
11. 下 列 对 于 构造 方法 的 描述 中 ， 正 确 的 是 (  ”)。 
A. 构造 方法 必须 用 void 声明 返回 类 型 
B. 构造 方法 名 必须 与 类 名 相同 
C. 构造 方法 可 以 被 程序 调用 
D. 如 果 编 程 人 员 没 在 类 中 定义 构造 方法 ， 程 序 将 报错 
12. 下列 有 关 继 承 的 描述 中 ， 正 确 的 是 5 


A. 子 类 能 继承 父 类 的 非 私有 方法 和 属性 
B. 子 类 能 继承 父 类 的 所 有 方法 和 属性 
C. 子 类 只 能 继承 父 类 的 公有 方法 和 属性 
D. 子 类 能 继承 父 类 的 方法 ， 而 不 是 属性 
13. 下 面 有 关子 类 继承 父 类 构造 方法 的 描述 中 ， 正 确 的 是 ( ” )。 
A. 创建 子 类 的 对 象 时 ， 先 调用 子 类 自己 的 构造 方法 ， 然 后 调用 父 类 的 构造 方法 
B. 子 类 会 继承 父 类 的 构造 方法 
C. 子 类 必须 通过 关键 字 super 调用 父 类 的 构造 方法 
D. 子 类 无 法 继承 父 类 的 构造 方法 
14. 下 列 关 于 Java 语言 基础 知识 的 描述 中 ， 正 确 的 是 (  )。 
A. 类 是 方法 和 变量 的 集合 体 B. 抽象 类 或 接口 可 以 被 实例 化 
C. 数组 是 无 序数 据 的 集合 D. 类 成 员 数 据 必须 是 公有 的 


15. 有 如 下 代码 : 
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public class Test 
public static void main(String[] args) 
| class A 
{ 
public int 1=3; 
1 
oi 0= (Object)new A(); 
Aa=(A)o; 
System.out.println("i = "+ a.D; 
} 
} 
上 述 程序 运行 后 的 结果 是 《 入 
A. i=3 B. 编译 失败 
C. 运行 结果 为 ClassCastException D. i=0 
二 、 填 空 题 
1. 用 于 声明 一 个 类 为 抽象 类 的 关键 字 是 〈 ”)， 用 于 将 一 个 类 修饰 为 最 终 类 的 关键 字 
是 (  )。 
2. 构造 方法 、 成 员 变 量 初始 化 以 及 静态 成 员 变 量 初始 化 三 者 的 先后 顺序 是 ( )。 
3. 在 Java 语言 的 基本 数据 类 型 中 ， 字 符 型 、 整 型 分 别 占 用 字 节 数 为 〈 JR ) 
4. 一 般 有 两 种 用 于 创建 线程 对 象 的 方法 ， 分 别 是 ) 与 人 ba 
5. Java 语言 提供 了 两 种 用 于 多 态 的 机 制 ， 分 别 是 〈 》 与 人 本 
三 、 问 答题 
1. 接口 能 否 继承 接口 ? 抽象 类 是 否 可 实现 〈implements) 接口 ? 抽象 类 是 否 可 继承 实体 类 ? 
2. 面向 对 象 的 特征 有 哪些 方面 ? 
3. String 和 StringBuffer 有 什么 区 别 ? 
4. final、finally 和 finalize 的 区 别 是 什么 ? 
5. ArrayList、Vector 和 LinkedList 有 什么 特点 ? HashMap 和 HashTable 有 什么 区 别 ? 


四 、 附 加 题 

1. 编写 一 个 截取 字符 串 的 函数 ， 输 入 为 一 个 字符 串 和 字 节 数 ， 输 出 为 按 字 节 截取 的 字符 
串 。 但 是 要 保证 汉字 不 被 截 半 个 ， 例 如 “人 ABC”4， 应 该 截 为 “人 AB”， 输 入 “人 ABC 们 
DEF” 6， 应 该 输出 为 “人 ABC” 而 不 是 “人 ABC+ 们 的 半 个 ”。 

2. 排序 有 哪 几 种 方法 ? 用 Java 语言 实现 一 个 插入 排序 ? 


某 知名 互联 网 金融 企业 软件 工程 师 笔试 是 


一 、 单 项 选择 题 
1. 和 下列 描述 中 ， 正 确 的 是 )。 
A. Java 程序 经 编译 后 会 产生 Machine Code (机 器 人 码 ) 
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B. Java 程序 经 编译 后 会 产生 Byte Code〈 字 节 码 ) 
C.Java 程序 经 编译 后 会 产生 DLL 〈 动 态 链接 库 ) 
D. 以 上 描述 都 不 正确 
2. Java 语言 是 从 ) 语言 改进 重新 设计 的 。 
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A. BASIC B. C++ C. Pascal D. Ada 
3. 下 列 关 于 类 的 插 述 中 ， 正 确 的 是 ( ” )。 

A. 类 中 的 构造 方法 不 可 省 略 

B. 一 个 类 只 能 定义 一 个 构造 方法 

C. new 一 个 对 象 的 时 候 构造 方法 会 被 调用 

D. 构造 方法 必须 与 类 同名 ， 但 普通 方法 不 能 与 类 同名 
4. 下 列 选项 中 ， 提 供 了 Java 存 取 数 据 库 能 力 的 包 是 (  ”)。 

A. java.sql B. java.swing 

C. java.io D. java.awt 
5. 下 列 运算 符合 法 的 是 ( ””)。 

A. KK B. ~ C. while D. := 
6. 有 如 下 代码 : 

a=0; 

c=0; 

dof{ 

--c; 

a=a-1; 

}while(a>0); 
当 执 行 完 以 上 代码 后 ， 变 量 c 的 值 是 〈 )。 

A. -2 B. 1 C. -1 D. 和 死 循环 


7. 下 列 关 于 abstract 的 描述 中 ， 正 确 的 是 〈 元 
A. abstract 修饰 符 可 修饰 属性 、 方 法 和 类 
B. 抽象 方法 的 方法 体 必 须 用 一 对 大 括号 包 住 
C. 抽象 方法 的 方法 体 〈 大 括号 ) 可 有 可 无 
D. 声明 抽象 方法 不 可 写 出 大 括号 

8. 下 列 关 于 形式 参数 的 描述 中 ， 正 确 的 是 )e 
A. 形式 参数 可 被 视 为 局 部 变量 
B. 形式 参数 不 可 以 是 对 象 
C. 形式 参数 为 方法 被 调用 时 真正 被 传递 的 参数 
D. 形式 参数 可 被 字段 修饰 符 修饰 

9. 下 列 关 于 实例 方法 的 描述 中 ， 正 确 的 是 )。 
A. 实例 方法 可 直接 调用 超 类 的 类 方法 
B. 实例 方法 可 直接 调用 超 类 的 实例 方法 
C. 实例 方法 可 直接 调用 其 他 类 的 实例 方法 
D. 实例 方法 可 直接 调用 本 类 的 类 方法 


El 


el 


10. 下 列 关 于 Java 语言 的 描述 中 ， 正 确 的 是 
A. Java 语言 容许 单独 的 过 程 与 函数 存在 
B. Java 语言 容许 单独 的 方法 存在 
C. Java 语言 中 的 方法 属于 类 中 的 成 员 
D. Java 语言 中 的 方法 必定 隶属 于 某 一 类 (对象 ) 
二 、 多 项 选择 题 
1. 下 列 关 于 Java 语言 的 编译 过 程 的 描述 中 ， 正 确 的 有 ( D's 
A. 环境 变量 可 在 编译 source code 时 指定 
B. 在 编译 程序 时 ， 所 能 指定 的 环境 变量 不 包括 class path 
C. javac 一 次 可 同时 编译 数 个 Java 源 文件 
D. javac.exe 能 指定 编译 结果 要 置 于 哪个 目录 (directory) 
2. 下 列 标识 符 中 ， 不 合法 的 有 ( Ds 


A. if B. $Usdollars 

C. 12345 D. t.txt 
3 下列 关 于 数组 的 描述 中 ， 错 误 的 有 )。 

A. 数组 是 一 种 对 象 B. 数组 是 一 种 原生 类 

C. intarr=[]={1,2,3,4} D. 数组 的 大 小 可 以 随意 改变 
4， 以 下 不 能 用 来 修饰 接口 的 有 总 

A. private B. public C. abstract D. static 


5. 下 列 关 于 按 值 传递 与 按 引用 传递 的 描述 中 ， 正 确 的 是 让 
A. 按 值 传递 不 会 改变 实际 参数 的 数值 
B. 按 引 用 传递 能 改变 实际 参数 的 参考 地 址 
C. 按 引 用 传递 能 改变 实际 参数 的 内 容 
D. 按 引 用 传递 不 能 改变 实际 参数 的 参考 地 址 

6. 下 列 关 于 类 方法 的 调用 的 描述 中 ， 错 误 的 有 js 
A. 在 类 方法 中 可 用 this 来 调用 本 类 的 类 方法 
B. 在 类 方法 中 调用 本 类 的 类 方法 时 可 直接 调用 
C. 在 类 方法 中 只 能 调用 本 类 中 的 类 方法 
D. 在 类 方法 中 绝对 不 能 调用 实例 方法 

7. 下 列 关 于 Java 语言 基础 知识 的 描述 中 ， 错 误 的 有 ( )。 
A. 能 被 java.exe 成 功 运行 的 java class 文件 必须 有 main() 方 法 
B. J2SDK 就 是 Java API 
C. Appletviewerexe 可 利用 jar 选项 运行 .jar 文件 
D. 能 被 Appletviewer 成 功 运 行 的 java class 文件 必须 有 main0 方 法 

三 、 判 断 题 

1. Unicode 是 用 16 位 来 表示 一 个 字 的 。(  ) 

2. Java 程序 中 的 起 始 类 名 称 必须 与 存放 该 类 的 文件 名 相同 。( ) 

3. 原生 类 中 的 数据 类 型 均 可 任意 转换 。( ) 
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四 、 程 序 题 
1， 写 出 下 列 程序 的 运行 结果 


public class Test 


public static void main(String[] args) 
{ 
String a = "hello"; 
change(a); 
System.out.println(a); 
} 
public static void change(String name) 
{ 
name="world"; 
} 
} 


2. 写 出 下 面 程序 运行 的 结果 


public class Test 


{ 
static boolean f(char c) 
{ 
System.out.print(c ); 
return true; 
} 
public static void main(String[] argv) 
{ 
inti= 0; 
for (f(A"); KBD) && (i1< 2); fC")) 
{ 
计 卡 
f(D"); 
} 
} 
} 


五 、 简 答题 
HashMap 和 HashTable 的 区 别 是 什么 ? 
入 和 && 的 区 别 是 什么 ? 
Collection 和 Collections 的 区 
abstract class 和 interface 的 区 别 
Final、finally 和 finalize 的 区 


wm 上 wm 一 


是 设计 模式 ? 有 哪些 常见 的 设计 模式 ? 
. 请 简要 介绍 Spring MVC、IoC 和 AOP。 
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一 、 单 选 题 

1. 下 列 关 于 实例 方法 的 描述 中 ， 正 确 的 是 )。 
A. 实例 方法 可 直接 调用 超 类 的 类 方法 
B. 实例 方法 可 直接 调用 超 类 的 实例 方法 
C. 实例 方法 可 直接 调用 其 他 类 的 实例 方法 
D. 实例 方法 可 直接 调用 本 类 的 类 方法 

2. 下 列 关 于 抽象 方法 的 描述 中 ， 正 确 的 是 〈 )。 
A. 抽象 方法 的 body 部 分 必须 用 一 对 大 括号 { } 包 住 
B. abstract 修饰 符 可 修饰 字段 、 方 法 和 类 
C. 声明 抽象 方法 ， 大 插 号 可 有 可 无 
D. 声明 抽象 方法 不 可 写 出 大 括号 

3. 有 如 下 代码 : 


public class Test 
{ 
public int f() 
4 
static int 1= 0; 
二 十 ; 
return i; 
} 
public static void main(String args[]) 
{ 
Test test = new Test(); 
test.f(); 
intj = test.f(); 
System.out.printin(); 
} 
} 


上 述 代码 的 输出 结果 是 〈 
A. 0 B. 2 CT D. 编译 失败 
4. 有 如 下 代码 : 


class Super 
{ 
public Integer getLenght() 
{ 
return new Integer(4); 
} 
} 
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public class Sub extends Super 
{ 
public Long getLenght() 
{ 
return new Long(5); 
} 
public static void main(String[] args) 
{ 
Super super = new Super(); 
Sub sub = new Sub(); 
System.out.println(Super.getLenght(O.toString() + "," +sub.getLenght()); 
} 
} 
上 述 代 码 的 输出 结果 是 )s 
A. 4,5 B. 4,4 C. 5,4 D. 编译 失败 
5. Servlet 处 理 请 求 的 方式 为 《 )。 
A. 以 程序 的 方式 B. 以 进程 的 方式 
C. 以 线程 的 方式 D.， 以 啊 应 的 方式 
6. 在 JDBC 中 ， 用 于 表示 数据 库 连接 的 对 象 是 )。 
A. Statement B. Connection C. PreparedStatement D. DriverManager 
7. 在 Java 语言 中 ， 用 于 调用 存储 过 程 的 对 象 是 〈 庆 
A. DriverManager B. ResultSet C. CallableStatemet  D. PreparedStatement 
8. 下 面 关 于 垃圾 回收 的 描述 中 ， 正 确 的 是 ( ” ”)。 


A. 对 和 象 空间 被 回收 掉 之 后 ， 会 执行 该 对 象 的 finalize 方法 

B. 一 个 对 象 一 旦 成 为 垃圾 ， 就 立刻 被 回收 

C. finalize 方法 和 C++ 语言 的 析 构 函数 完全 是 一 回 事 

D. 一 个 对 象 成 为 垃圾 是 因为 不 再 有 引用 指 着 它 ， 但 是 线程 并 非 如 此 
9. 按照 MVC 设计 模式 ，JSP 用 于 实现 站 


A. Controller( 控 制 器 ) B. View (视图 ) 
C. Model (模型 ) D. Database (数据 库 ) 


10. 有 如 下 代码 : 


10) public Object mO) { 

11) Object o = new Float(3.1f); 
12) Object [] 0a = new Object[1]; 
13) oa[0] = 0; 

14) o = null; 

15) oa[0] = null; 

16) print return 0'; 

17)} 


当 Float 对 象 在 第 11 行 被 创建 后 ，(  ”) 能 够 被 垃圾 回收 。 


34 


A. 14 行 以 后 B. 13 行 以 后 C. 15 行 以 后 D. 16 行 以 后 
11. 有 如 下 代码 : 


class Base 


{ 
Base() 


{ 


System.out.print("Base"); 


} 


} 


public class Alpha extends Base 


: public static void main(String[] args) 
: new Alpha(); 
new Base(); 
} 
} 
上 述 代码 的 输出 结果 是 95 
A. Base B. BaseBase C. 运行 失败 D. 编译 失败 
12. 在 J2EE 中 ， 属 于 Web 层 的 组 件 有 (  ”)。 
A. Servlet B. HIML C. Applet D. EJB 
13， 以 下 关于 异常 的 描述 中 ， 正 确 的 是  )。 


A. 如 果 一 个 方法 声明 将 抛 出 某 个 异常 ， 它 就 必须 真 的 抛 出 那个 异常 
B. 一 旦 出 现 异 常 ， 程 序 运 行 就 终止 
C. 在 catch 子 句 中 匹配 异常 是 一 种 精确 匹配 
D. 可 能 抛 出 系统 异常 的 方法 是 不 需要 声明 异常 的 
14. 有 如 下 代码 : 


public class Test 


{ 
public static void main(String[] args) 
{ 
try 
{ 
return; 
} 
finally 
{ 
System.out.println("Finally"); 
} 
} 
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上 述 代码 的 输出 结果 是 “〈 


A. Finally 


C. 运行 时 抛 出 异常 
15. 在 JSP 指令 中 ，isELIgnored="boolean" 的 意思 是 ( DR 
A. 决定 该 页 面 是 否 是 一 个 错误 处 理 页 面 B. 决定 是 否 实现 servlet 的 单线 程 模式 


Ys 
B. 编译 失败 


D. 代码 正常 运行 但 没有 任何 输出 


16. 以 下 关于 Java 语言 中 的 引用 的 描述 中 ， 正 确 的 是 (  ”)。 
A. 引用 实际 上 就 是 指针 B. 引用 本 身 是 Primitive 


C. 一 个 对 象 只 能 被 一 个 引用 所 指引 


17. 以 下 关于 import java.util 包 的 描述 中 ， 错 误 的 是 ys 


A. Vector 类 放 在 /java/util/ 目 录 下 
C. Vector 类 放 在 java.util 文件 中 


18. 下 列 属于 容器 型 构件 的 是 ( ” )，。 


A. JButton 


19. 在 一 个 线程 中 ，sleep(100) 方 法 将 使 得 该 线程 在 ( 


B. JEdit C. JPanel 


睡眠 过 程 中 不 会 有 其 他 事件 唤醒 该 线程 )。 


C. 决定 是 否 支 持 EL 表示 D. 没有 具体 的 含义 


D. 引用 就 是 对 象 本 身 


D. JIextFlield 
) 后 获得 对 CPU 的 控 


B. Vector 类 属于 java.util 包 
D. Vector 类 是 Sun 公司 的 产品 


症 《假设 
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A. 正好 100ms B. 100ms 不 到 C. 宇 100ms D. 不 一 定 
20. 下 面 不 是 Java 语言 关键 字 的 是 ( 知 

A. integer B. float C. double D. default 
21. 在 WEB-INF 目录 下 ， 必 须 存放 的 文件 为 ( ” )。 

A. class 文件 B. web.xml C. html 文件 D. jar 文件 
22. 表达 式 4&7 的 运算 结果 是 (  )。 

A. 4 B. 1 C.6 D. 7 
23. 有 如 下 代码 : 

long temp=(int)3.9; 

temp%=2; 
那么 ， 变 量 temp 的 最 终 值 是 ( )。 

A. 0 B. 1 C2 D. 4 
24. 以 下 可 以 奉 换 URL 中 的 session ID 的 方法 是 

A. HttpServletRequest 接口 的 encodeURL 方法 

B. HttpServletResponse 接口 的 encodeURL 方法 

C. HttpServletResponse 接口 的 rewriteURL 方法 

D. HttpServletRequest 接口 的 rewriteURL 方法 
25. 每 个 使 用 Swing 构件 的 程序 必须 有 一 个 )。 

A. 标签 B. 按钮 C. 菜单 D. 容器 
26. 下 列 标识 符 命 名 原则 中 ， 正 确 的 是 《〈 )。 

A. 变量 和 方法 名 的 首 写字 母 大 写 B. 类 名 的 首 字母 小 写 

C. 接口 名 的 首 写 字母 小 写 D. 常量 完全 大 写 


27， 


类 Test 定义 如 下 : 


1) public class Test{ 

2) public float f(float a, float b){ return 0;} 
3) 

4)} 


将 选项 ( ””) 中 代码 插入 第 3 行 是 不 合法 的 。 


28. 


29. 


30. 


31. 


32. 


33. 


34. 


35. 


36. 


A. publicfloatf(floata, floatb, floatc) {return 0;} 
B. public floatf (float c, floatd) {return 0;} 

C. public intf(inta, intb) {return 0;} 

D. private floatf (inta, int b, floatc) {return 0;} 

以 下 描述 中 ， 能 够 创建 一 个 数组 实例 的 是 ) 


A. int[] arr= new int [10]; B. floatfa= new float [10j]; 

C. char[] ca = “hello”; D. itia[][ = {1,2,3} {4,5, 6}; 
以 public 修饰 的 类 如 下 所 示 : public class Car{...}， 则 类 Car ( 3 

A. 可 被 其 他 程序 包 中 的 类 使 用 B. 不 能 被 其 他 类 继承 

C. 不 能 被 任意 其 他 类 使 用 D. 仅 能 被 本 程序 包 中 的 类 使 用 
Java 程序 的 执行 过 程 中 用 到 一 套 JDK 工具 ， 其 中 ，java.exe 是 指 ( 

A. Java 编译 器 B. Java 解释 器 

C.Java 文档 生成 器 D. Java 类 分 解 器 


下 列 关 于 构造 方法 的 描述 中 ， 错 误 的 是 )。 

A. Java 语言 规定 构造 方法 没有 返回 值 ， 但 不 用 void 声明 
B. Java 语言 规定 构造 方法 名 与 类 名 必须 相同 

C.Java 语言 规定 构造 方法 不 可 以 重 载 

D. Java 语言 规定 构造 方法 不 能 直接 被 调用 


构造 方法 调用 的 时 间 是 〈 

A. 定义 类 时 B. 创建 对 象 时 

C. 使 用 对 象 的 变量 时 D. 调用 对 象 方法 时 

以 下 关于 关键 字 break 的 描述 中 ， 正 确 的 是 〈 

A. 只 中 断 最 外 层 的 循环 B. 只 中 断 最 内 层 的 循环 
C. 借助 于 标 叶 ， 可 以 实现 任何 外 层 循环 中 断 D. 只 中 断 某 一 层 的 循环 


在 Java 语言 中 ， 下 面 可 以 用 作 正 确 的 变量 名 称 的 是 《 

A. lx B. age C. extends D. implements 
在 JavaScript 中 ， 以 下 验证 一 个 数据 是 否 是 数字 的 描述 中 ， 正 确 的 是 )。 
A. intI=value 若 报 错 就 不 是 数字 

B. 如 果 用 Integer.parseInt(value) 有 误 就 不 是 数字 

C. 没有 方法 验证 
D. 利用 isNaN(value) 返回 的 boolean 进行 判断 
以 下 不 能 作 JSP 的 服务 器 的 是 a 
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A. JBoss B. BEA WebLogic C. Tomcat D. PWS 
37. 以 下 不 是 JSP 操作 指令 的 是 (  )。 

A. setProperty B. include C. forward D. import 
38. 下 面 不 是 Java 类 访问 控制 关键 学 的 是 (  ”)。 

A. private B. protected C. this D. public 
39. 如 果 和 希望 控件 在 界面 上 按 表 格 行 分 列 排列 ， 应 使 用 的 布局 管理 器 是 (  )。 

A. BoxLayout B. GridLayout C. FlowLouLayout D. BorderLayout 
40. 在 配置 tomcat 虚拟 目录 时 ， 需 要 打开 的 文件 是 Ds 

A. web.xml B. index.jsp C. server.xml D. 以 上 都 不 是 
41. 下 面 不 是 表单 标记 的 是 ( )。 

A. RADIO B. INPUT C. CHECKBOX D. TR 
42. 下 面 不 是 response 对 象 的 方法 的 是 ( Xe 


A. addCookie(Cookie cookie) 

B. setHeader(String headername,String headervalue) 
C. getParameter(String str) 

D. sendError(int errorcode) 


43. 以 下 是 编写 Servlet 必须 导入 的 包 的 是 (  )。 


A. java.sql.* B. java.servlet.* C. java.util.* D. java.io.* 
44. 下 面 不 属于 SQL 语句 的 子 类 的 是 (  )。 

A. 数据 查询 语言 (DQL) B. 数据 定义 语言 (DDL) 

C. 事务 控制 语言 (TCL) D. 数据 插入 语言 (DIL) 


45. 有 如 下 代码 : 


public class Outer 
{ 
public void someOuterMethod() 


{ 
// Line 3 


} 
public class Inner{} 
public static void main(String[]argv) 
{ 
Outer o = new Outer(); 
// Line 8 


} 


内 部 类 里 面 实例 化 了 一 个 实例 的 是 (  )。 
A. new Inner();// At line 3 B. new Inner(); /Atlne 8 
C. new Outer.Inner(); // At line 8 D. new o.Inner(); /Atlne 8 
二 、 多 选 题 
1. 以 下 声明 中 ， 能 够 防止 方法 履 盖 的 有 ) 
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A. final void f() {} 也 .void final f() {} 
C. static void f() {} D. static final void f0) 全 
E. final abstract void f() {} 

2. 下 列 属于 JSP 中 注释 的 有 ( )。 


Ny B. / GC pe D. <%-- 与 --%> 
3. 按照 学 生平 均 成 绩 (avg_grade) 将 students 表 中 的 数据 检索 出 来 ， 下 面 SQL 语句 正 
是 


( 
A. SELECT * FROM students ORDER BY avg grade 

B. SELECT * FROM students GROUP BY avg grade ASC 
C. SELECT * FROM students GROUP BY avg_ grade DESC 
D. SELECT * FROM students ORDER by avg grade asc 

4. 下 列 是 JSP 作用 域 的 通信 对 象 的 有 ( )。 


A. application B. session C. pageContext D. cookie 
5. 在 接口 中 ， 以 下 定义 正确 的 是 (  )。 

A. voidf(); B. public double f(); 

C. public final double f(); D. static void 人 double d1); 


E. protected void f(double d1); 
6. 下 面 语句 中 ， 正 确 地 声明 一 个 整 型 的 二 维 数 组 的 有 (  ” )。 
A. int ar[l][]=new int[]lj; B. int arr[20][10]=new int[][]; 
C. char alll]l=new char[10][10]; DD. int UUa=new int[10][20]; 
E. int [Jjal]l=new int[10][10]; 
7. 下 面 不 是 Java 语言 的 原始 数据 类 型 的 有 (  ”)。 
A. int B. Boolean C. Double D. char 
8. 下 面 能 够 生成 5 个 空 字符 串 的 语句 有 (  )。 
A. String all=new String[$5]: for(int i1=0; 1<$5; alit+]="™); 
也 String a[lfs{®, YY, ,YO}; 
C. Strng alsj; 
D. String [Ja=new String[5]; forGint i=0; 1<5; a[i++]=nu]); 
9. 以 下 关于 数组 的 描述 中 ， 错 误 的 有 1 


A. 数组 是 一 种 对 象 B. 数组 属于 一 种 原生 类 

C. intnumber=[]={1,2,3,4,5} D. 数组 的 大 小 可 以 随意 改变 
10. 不 能 用 来 修饰 interface 的 有 )。 

A. private B. public C. final D. static 


11. 下 列 关 于 类 方法 的 描述 中 ， 错 误 的 有 ( 庆 
A. 在 类 方法 中 可 用 this 来 调用 本 类 的 类 方法 
B. 在 类 方法 中 调用 本 类 的 类 方法 时 可 直接 调用 
C. 在 类 方法 中 绝对 不 能 调用 实例 方法 
D. 在 类 方法 中 只 能 调用 本 类 中 的 类 方法 

12. 有 如 下 代码 : 
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classSAT{ 
AU {} 
} 


class B extends A { 


} 


关于 上 述 代码 ， 以 下 描述 正确 的 是 he 
A. B 类 的 构造 方法 一 定 是 public ”B. B 类 的 构造 方法 应 该 是 没有 参数 
C. B 类 的 构造 方法 应 该 调用 this() ”D. B 类 的 构造 方法 应 该 调用 super() 
13. 下 列 标识 符 中 ， 不 合法 的 有 ( )。 


A. 下 B. $aa €; 12 D. a.txt 
14. 以 下 能 使 用 throw 抛 出 异常 的 有 (  ”)。 
A. Throwable B. Event C. Object D. Error 
E. Exception F. RuntimeException 
15. 在 javax.Servlet 的 包 中 ， 属 于 类 的 是 ( Ds 
A. Servlet B. ServletException 
C. GenericServlet D. ServletContext 
16. 有 如 下 代码 : 


public class X { 
public X f() { return this;} 


} 


public class Y extends X { 


} 


以 下 能 添加 到 YY 类 的 定义 中 的 方法 是 (  ”)。 
A. public void f() {} B. private void f() {} 
C. public void f(String s) {} D. private Y f() { return null;} 
E. public X f() {return new Y();} 
17. 有 如 下 代码 <% int i = Integer.parseInt(request.getParemeter(“value”)) %>， 下 面 描述 正 
确 的 有 5 


A. 不 会 有 错 
C. 当 value 王 " " 时 会 报错 
B. 当 value 与 int 类 型 不 匹配 时 会 报错 


D. 为 了 安全 起 见 应 该 将 该 段 代 码 放 在 try{} 和 catch0 人 之 间 
18. 以 下 哪 两 个 是 等 价 的 ? (  ) 
A. <%= YoshiBean.size%> 
. <%= YoshiBean.getSize()%> 
. <%= YoshiBean.getProperty("size")% 
. <JSP:getProperty id="YoshiBean" param="size"/> 


. <jsp:getProperty id="YoshiBean" property="size"/> 


可 DOR 


<jsp:getProperty name="Y oshiBean" param="size"/> 
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G. <jsp:getProperty name="YoshiBean" property="size"/> 
19. 以 下 关于 构造 方法 的 描述 中 ， 正 确 的 有 人 
A. 默认 构造 方法 初始 化 方法 变量 
B. 默认 构造 方法 调用 其 父 类 的 无 参 构造 器 
C. 默认 构造 方法 有 和 它 所 在 类 相同 的 访问 修饰 符 
D. 
E. 


Wl 


如 果 一 个 类 没有 无 参 构造 方法 ， 编 译 器 会 为 它 创建 一 个 默认 构造 方法 
只 有 当 一 个 类 没有 任何 构造 方法 时 ， 编 译 器 才 会 为 它 创 建 一 个 默认 构造 方法 
20. 在 Servlet 的 生命 周期 中 ， 容 器 只 调用 一 次 的 方法 是 〈 )。 

A. getServletConfig B. service C. init D. destroy 


NS 


~ 


大 全 人 


、 简 答题 

.关键 字 static 的 作用 是 什么 ? 

JSP 和 Servlet 有 哪些 相同 点 和 不 同 点 ?它们 之 间 的 联系 是 什么 ? 

switch 是 否 能 作用 在 byte 上 ? 是 否 能 作用 在 long 上 ? 是 否 能 作用 在 String 上 ? 

.数据 连接 池 的 工作 机 制 是 什么 ? 

.多 线程 同步 有 儿 种 实现 方法 ? 

HTML 的 Form 和 XForm 的 区 别 是 什么 ? 

forward 和 redirect 的 区 别 是 什么 ? 

Overload 和 Override 的 区 别 是 什么 ? Overload 的 方法 是 否 可 以 改变 返回 值 的 类 型 ? 
. 下 面 的 Java 代码 保存 在 B.java 文件 中 是 否 合 法 ? 


Ro. 


class A 


{ 


publicstaticvoid main(String args[]) 


{ 
System.out.println("Hello World"); 


} 


} 


10. Servlet 和 CGI 的 区 别 是 什么 ? 
四 、 编 程 题 

1. 对 数组 进行 顺序 排列 。 

2. 用 Java 语言 写 一 段 访问 Oracle 数据 库 的 程序 ， 并 实现 数据 查询 。 
3. 请 给 出 单 例 模 式 的 实现 代码 。 

4. 用 循环 控制 语句 打印 输出 : 1+3+5+…+99 的 结果 。 


某 初创 公司 软件 工程 师 笔 试题 


一 、 选 择 题 〈 可 多 选 ) 

1. Java 之 所 以 可 以 实现 跨 平 台 ， 是 因为 Java 程序 在 运行 时 使 用 了 )s 
A. JRE (Java Runtime Environment ) B. JDK (Java Development Kit ) 
C. JVM (Java Virtual Machine ) D. OS (Operating System ) 
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2， 有 如 下 代码 : 


intn 三 999; 


System.out.println( n++ ); 
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以 上 程序 中 ， 程 序 的 输出 结果 为 (  )。 
A. 98 B. 999 C. 1000 D. 1001 
3. 下 列 选项 中 ， 是 Java 语言 中 的 关键 字 的 是 (  ”)。 
A. public B. Static C. main D. if 
4. 以 下 是 合法 的 byte 类 型 的 数据 的 是 ( ” ”)。 
四 ,=129 B. 127 C. 128 D. (ntb-130 
5. 有 如 下 代码 : 
byte b= (byte)129; 
那么 ， 变 量 b 的 值 是 ( )。 
A. —126 B. —127 C. —128 D. —129 
6. 在 JDK 1.7 中 ， 对 于 switch 语句 ，switch 后 面 的 括号 中 不 可 以 是 ( ””) 类 型 。 
A. int B. byte C. short D. char 
E. String F. 枚 举 G. float H. double 
7. 有 以 下 代码 : 
for (inti=4;1> 0; i--) 
{ 
intj = 0; 
do 
{ 
jtt; 
if (==2) 
{ 
break; 
} 
} while ( <=i); 
System.out.print(]); 
} 
程序 的 输出 结果 是  )。 
A. 4321 B. 1232 Cr 221]1 D. 2222 
8. 以 下 声明 数组 的 方式 中 ， 正 确 的 是 (  ”)。 
A. int[1][4] arr; B. char[3] [] arr; C. char [] arr [] ; 
D. String[]U arr  E. Objectarr[][j; 上 .shortarr[][ 3 ]; 
9. 下 列 关 于 package 和 import 语句 的 描述 中 ， 错 误 的 是 〈 )。 


A. 同一 个 类 中 package 语句 可 以 出 现 一 次 或 多 次 


B. 同一 个 类 中 import 语句 可 以 出 现 一 次 或 多 次 
C.， 同一 个 类 中 import 语句 必须 出 现在 该 类 的 第 一 行 〈 不 含 注 释 ) 
D. 同一 个 类 中 package 语句 必须 出 现在 该 类 的 第 一 行 ( 不 含 注释 ) 
10. 以 下 关于 可 变 长 参数 的 定义 中 ， 正 确 的 是 (  )。 
A. public void f( String[] aa, String... a ){} 
B. public void f( String a, double b , String... a){} 
C. public void f String... a ){} 
D. public void f String... a, String[] aa){} 
11. 有 如 下 代码 : 


public interface Usb { 


} 


public abstract class Interface { 


} 


以 下 关于 接口 的 使 用 中 ， 正 确 的 是 (  )。 
A. public interface Usbl extends Usb {} 
B. public interface Usbl extends Interface {} 
C. public interface Usbl implements Usb {} 
D. public interface Usbl implements Interface {} 
12. 以 下 关于 Map 的 用 法 中 ， 正 确 的 有 (  ”)。 
A. new java.util.SortedMap().put("key1" , "valuel");; 
B. new java.util.Map().put("keyl" , "valuel"); 


C. new java.util.HashMap().put( null , null ) ; 
D. new java.util.TreeMap().put( 0 , null ) ; 
13. 以 下 不 是 Collection 的 子 接口 的 是 ( )。 
A. List B. Set C. SortedSet D. HashMap 
下 面 对 于 异常 处 理 的 描述 中 ， 正 确 的 是 ja 
A. 捕获 异常 是 通过 try、catch 等 关键 字 来 实现 ， 这 是 一 种 积极 的 异常 处 理 方式 
B 
C 


14. 


. try 必须 跟 catch 连用 ， 而 finally 是 可 有 可 无 的 
. catch 之 后 的 ( ) 用 于 接收 异常 对 象 ， 因 此 需要 指定 类 型 和 变量 名 称 ， 比 如 
catch( Exception e ) 
D. 对 于 finally 代码 块 而 言 ， 仪 当 执 行 try 语句 并 没有 触发 异常 时 才 执 行 ， 如 果 发 生 
异常 则 进入 catch 代码 块 ， 不 再 执行 fnally 代码 块 
E. 在 JDK 1.7 中 , 允许 在 catch 中 捕获 多 个 类 型 异常 , 如 catch( NullPointer Exception 
el | ClassCastException e2) 
15. HashTable 和 HashMap 的 区 别 是 )。 
A. HashTable 是 一 个 哈 希 表 ， 该 类 继承 了 AbstractMap， 实 现 了 Map 接口 
B. HashMap 是 内 部 基于 哈 希 表 实 现 ， 该 类 继承 AbstractMap， 实 现 Map 接 
C. HashTable 线程 安全 的 ， 而 HashMap 是 线程 不 安全 的 
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D. HashTable 直接 使 用 对 象 的 HashCode， 而 HashMap 重新 计算 Hash 值 
EE. Properties 类 继承 了 HashTable 类 ， 而 HashTable 类 则 继承 Dictionary 类 
16. 以 下 关于 随机 数 的 描述 中 ， 正 确 的 是 〈 )s 
A. Math.random() 可 以 生成 [0,1] 内 的 任意 小 数 
B. Random.next(10) 可 以 生成 [0, 10] 内 的 任意 整数 
C. new java.util.Random(.nextInt(11) 可 以 生成 [0,10] 内 的 任意 整数 
D. new java.util.MathO.random0 可 以 生成 [0,1) 内 的 任意 小 数 
、 简 答题 
. 为 什么 不 能 通过 返回 值 来 对 方法 进行 重 载 ? 
. 是否 可 以 用 volatile 来 修饰 数组 ? 
. a=atb 与 at=b 有 什么 不 同 ? 
.如 何 查 看 Java 程序 使 用 内 存 的 情况 ? 
四 种 会 话 跟踪 技术 是 什么 ? 
在 多 线程 编程 的 时 候 有 哪些 注意 事项 ? 
三 、 数 据 库 设 计 题 目 
有 如 下 学 生 信息 : 
学 生 表 student (stu_id，stu_name); 


课程 表 course (c_ id，c_name); 


I | 


成 绩 表 score (stu id，c_ id，score); 

1. 写 出 向 学 生 表 中 插入 一 条 数据 的 SQL 语句 。 
2. 查询 名 字 为 James 的 学 生 所 选 的 课程 。 
3. 查询 stu_ id 为 4 的 学 生 所 学 课程 的 成 绩 。 


某 知名 游戏 软件 开发 公司 软件 工程 师 笔试 题 


一 、 选 择 题 
1. 假设 某 算 法 的 时 间 复 杂 度 符合 递 推 关 系 式 T(n)=2T(n/2)tn， 那 么 该 算法 的 时 间 复 杂 度 
相当 于 (  )。 
A. O(n’2) B. O(logn) C. Omnlogn) D. O(n) 
2. 程序 和 进程 的 本 质 区 别 是 (  )。 
A. 独占 使 用 和 分 时 使 用 计算 机 资源 B. 非 顺序 和 顺序 执行 机 器 指令 
C. 在 外 存 和 内 存 存储 D. 静态 和 动态 特征 
3. 下 图 是 一 个 非 确 定 有 限 自 动机 (NFA)〉 的 状态 转换 图 ， 其 等 价 的 正规 式 为 (  ”)。 


(入 
8 
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A. 0*|(0|1)0 B. (0|10)* C. 0O*(10)* D. O*((0|1)0)* 
4. IPVv6 地 址 占 ( ) 个 字 节 。 
A. 32 B. 4 C. 8 D. 16 


5. 以 下 关于 RARP 协议 的 说 法 中 ， 正 确 的 是 ( )。 
A. RARP 协议 用 于 对 IP 协议 进行 差错 控制 
B. RARP 协议 根据 主机 IP 地 址 查询 对 应 的 MAC 地址 
C. RARP 协议 根据 MAC 地 址 求 主机 对 应 的 IP 地 址 
D. RARP 协议 根据 交换 的 路 由 信息 动态 改变 路 由 表 
二 、 简 答题 
1. 甲 、 乙 两 个 人 在 玩 猜 数 字 游 戏 ， 甲 随机 写 了 一 个 数字 ， 在 [1,100] 区 间 之 内 ， 将 这 个 数 
字 写 在 了 一 张 纸 上 ， 然 后 乙 来 猪 。 如 果 乙 猪 的 数字 偏 小 ， 甲 会 提示 :“ 数 字 偏 小 ”。 一 旦 乙 猪 
的 数字 偏 大 ， 甲 以 后 就 再 也 不 会 提示 了 ， 只 会 回答 “ 猪 对 或 猿 错 ”。 请 问 : 乙 至 少 猿 多 少 次 才 
可 以 准确 猜 出 这 个 数字 ? 在 这 种 策略 下 ， 乙 猜 的 第 一 个 数字 是 什么 ? 
2. 请 给 出 Java 异常 类 的 继承 体系 结构 ， 以 及 Java 异常 的 分 类 ， 且 为 每 种 类 型 的 异常 各 
举 几 个 例子 。 
3. 在 Web 开发 中 ， 如 何 实现 会 话 的 跟踪 ? 
4. 描述 Java 类 加 载 器 的 原理 及 其 组 织 结构 。 
5. 请 简 述 Spring 架构 中 IoC 的 实现 原理 。 
6. 下 面 程序 是 否 存 在 问题 ? 如 果 存 在 ， 请 指出 问题 所 在 ; 如果 不 存在 ， 请 说 明 输出 结果 。 


oo 


public class Test 
{ 
public static String result = ""; 
public static void fint i) 
{ 
try 
{ 
if (i== 1) 
{ 
throw new Exception(exception message); 


} 


} catch (Exception e) 

{ 
result += "2"; 
return; 

} finally 

{ 
result += "3"; 

} 

result += "4"; 

} 


public static void main(String[] args) 


{ 
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System.out.println(result); 
} 
7. 下 面 程 序 是 否 存在 问题 ?如 果 存 在 ， 请 指出 问题 所 在 ， 如 果 不 存在 ， 说 明 输 出 结果 。 


public class HelloB extends HelloA 
{ 


public HelloB() 
{ 


System.out.println("HelloB"); 


System.out.println("Tm B class"); 
} 
static 
{ 
System.out.printin("static B"); 
} 


public static void main(String[] args) 


{ 
new HelloB(); 


} 
class HelloA 


{ 
public HelloA() 


{ 
System.out.println("HelloA"); 


System.out.println("Tm A class"); 


} 
static { 
System.out.printin("static A"); 


} 


上 


8. 下面 程序 是 否 存在 问题 ? 如 果 存 在 ， 请 指出 问题 所 在 ， 如 果 不 存在 ， 说 明 输出 结果 。 


public class Test 


{ 


public static void main(String[] args) 


{ 


Test t= new Test(); 


inti= 0; 


t.increase(i); 
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i=it+; 
System.out.printin(i); 
} 
void increase(int 1) 
{ 
i 
} 


9. 下 面 程序 是 否 存 在 问题 ? 如 果 存 在 ， 请 指出 问题 所 在 ， 如 果 不 存 在 ， 说 明 输 出 结果 。 


public class Test 


{ 
public static void main(String[] args) 
{ 
String str = new String("good"); 
char[] ch = {'a','b','c'}; 
Test ex = new Test(); 
ex.change(str, ch); 
System.out.print(str +"and"); 
System.out.print(ch); 
} 
public void change(String str, char ch[]) 
{ 
str= "test ok"; 
ch[O= 'g’ 
} 
} 


10. 下 面 程序 是 否 存在 问题 ? 如 果 存 在 ， 请 指出 问题 所 在 ， 如果 不 存在 ， 说 明 输 出 结 


package packagel; 
import java.util.Date; 
public class Test extends Date 


private void test() 
+ 
System.out.printIn(super.getClass().getName()); 
} 
public static void main(String[] args) 
{ 
new Test().test(); 
} 


} 


三 、 算 法 题 
1. 有 两 个 有 序 的 集合 ， 集 合 中 的 每 个 元 素 都 是 一 段 范围 ， 求 其 交集 ， 例 如 集合 {[4，8]， 
[9，13j]} 和 {[6，12]} 的 交集 为 {[6，8]，[9，12]}。 


roy 


A 
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2. 任意 2n 个 整数 ， 从 其 中 选 出 n 个 整数 ， 使 得 选 出 的 na 个 整数 之 和 与 剩 下 的 mn 个 整数 
之 和 的 差 最 小 

3. 一 个 文件 中 有 10000 个 数 ， 用 Java 语言 实现 一 个 多 线程 程序 ， 将 这 10000 个 数 输出 
到 5 个 不 同文 件 中 (不 要 求 输出 到 每 个 文件 中 的 数量 相同 )。 要 求 启动 10 个 线程 ， 两 两 一 组 ， 
分 为 5 组。 每 组 两 个 线程 分 别 将 文件 中 的 奇数 和 偶数 输出 到 该 组 对 应 的 一 个 文件 中 ， 需 要 偶 
数 线程 每 打印 10 个 偶数 以 后 ， 就 将 奇数 线程 打印 10 个 奇数 ， 如 此 交替 进行 。 同 时 需要 记录 
输出 进度 ， 每 完成 1000 个 数 就 在 控制 台中 打印 当前 完成 数量 ， 并 在 所 有 线程 结束 后 ， 在 控制 


台 输 出 “Done”。 


某 知名 电子 商务 公司 软件 工程 师 笔 试题 


一 、 选 择 题 
1. Java 语言 中 字符 使 用 Unicode 编码 ， 每 个 Unicode 人 码 占用 ( ) bit。 


A. 4 B. 16 人 D. 64 
2. 已 知 有 如 下 定义 : String s="hello world";， 下 面 表 达 式 中 ， 不 合法 的 是 )s 
A. st="world" B. charc=s[1] 
C. intlen=s.length() D. String {t=s.toLowerCase() 
3. 欲 构 造 ArrayList 类 的 一 个 实例 , 此 类 继承 了 List 接口 , 下 列 方法 中 , 正确 的 是 ( js 
A. ArrayListlist= new Object() B. Listlist= new ArrayList() 
C. Listlist= new List() D. ArrayList list =new List() 


4. 以 下 关于 继承 的 描述 中 ， 正 确 的 是 )s 
A. 在 Java 语言 中 类 只 允许 单一 继承 
B. 在 Java 语言 中 一 个 类 只 能 实现 一 个 接口 
C. 在 Java 语言 中 ， 一 个 类 不 能 同时 继承 一 个 类 和 实现 一 个 接口 
D. 在 Java 语言 中 接口 只 允许 单一 实现 
5. 以 下 代码 是 SuperClass 和 Sub 两 个 类 的 定义 ,在 序列 化 一 个 Sub 的 对 象 sub 到 文件 
下 面 会 被 保存 到 文件 中 的 字段 是 ), 


Ty 


中， 


class SuperClass 


public String name; 


} 


class Sub extends SuperClass implements Serializable 


{ 
private float radius; 
transient int color; 
public static String type = “Sub”; 
} 
A. name B. radius C. color D. type 


6. Java 语言 的 接口 java.util.Collection 定义 了 许多 方法 ， 以 下 方法 中 ， 不 是 Collection 接 
口 所 定义 的 是 ( js 
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A. boolean containsAll(Collection c) B. int size() 
C. compareTo(Object obj) D. boolean equals(Object 0) 
7. 有 如 下 程序 段 : 


int x=3; 


int y=3; 


String S1= ”Hello”; 
String s2=” Hello”; 


圾 


则 表达 式 x 一 y 与 2==sl 的 结果 分 别 为 ( )。 


A. true 与 
C. true 与 


true B. false 与 true 
false D. false 与 false 


8. 下 列 关 于 类 方法 的 描述 中 ， 正 确 的 是 (  ”)。 


A. 在 类 方法 中 可 用 this 来 调用 本 类 的 类 方法 
B. 在 类 方法 中 调用 本 类 的 类 方法 时 可 直接 调用 
C. 在 类 方法 中 只 能 调用 本 类 中 的 类 方法 


D. 在 类 方 


法 中 绝对 不 能 调用 实例 方法 


9. 下 列 关 于 构造 方法 的 描述 中 ， 正 确 的 是 (  ”)。 
A. 类 中 的 构造 方法 不 可 省 略 
B. 构造 方 法 必须 与 类 同名 ， 但 方法 不 能 与 类 同名 
C. 构造 方法 在 一 个 对 象 被 new 时 执行 


D. 一 个 类 只 能 定义 一 个 构造 方法 


10. 以 下 关于 异常 处 理 机 制 的 描述 中 ， 正 确 的 有 )。 


A. catch 


部 分 捕捉 到 异常 情况 时 ， 才 会 执行 finally 部 分 


B. 不 论 程序 是 否 发 生 错 误 及 捕捉 到 异常 情况 ， 都 会 执行 finally 部 分 


C. 当 try 


区 段 的 程序 发 生 异 常 时 ， 才 会 执行 catch 区 段 的 程序 


D. 以 上 都 是 


二 、 问 答题 


1. ArrayList、 


Vector 和 LinkedList 的 存储 性 能 和 特性 是 什么 ? 


2. 垃圾 回收 器 的 原理 是 什么 ? 垃圾 回收 器 是 否 可 以 马上 回收 内 存 ? 如 何 通 知 虚拟 机 进行 垃 


回收 ? 


3. 下 面 代 人 码 是 否 可 以 进行 优化 ? 如 果 可 以 ， 怎 么 进行 优化 ? 


for(int 1=0;i 


} 


<1000;i+ 二 ) 
Object object = new Object(); 
System.out.println(“object name 1s”+object); 


Java 语言 


~ On 上 


XML 有 哪 


在 Java 语言 


实现 多 态 的 机 制 是 什么 ? 


数字 签名 和 加 密 的 区 别 是 什么 ? 


言 中 ，Socket 的 连接 和 建立 的 原理 是 什么 ? 
些 解析 技术 ? 它们 有 什么 不 同 点 ? 
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语言 中 有 几 种 方法 可 以 终止 线程 运行 ? stop0 和 suspend0 方 法 为 什么 不 推荐 


10. 用 一 条 SQL 语句 查询 出 每 门 课 都 大 于 75 分 的 学 生 姓 名 ， 表 名 为 score， 表 格式 


8. 数据 库 中 “事务 处 理 ” 指 的 是 什么 ? 
9. Java 
使 用 ? 
如 下 
name course 
六 至 语文 
张 三 数学 
李 四 语文 
李 四 数学 
乎 五 语文 
王 五 数学 
王 五 英语 


三 、 编 程 题 


mark 
81 

75 
76 
90 

81 
100 
90 


1. 寻找 一 条 从 左上 角 (arr[0][0]) 到 右 下 角 (arrfm-1][n-1])〉 的 路 线 ， 使 得 沿途 经 过 的 


数组 中 的 整数 之 和 最 小 。 


2. 使 用 两 种 方法 编写 多 线程 环境 下 的 Singleton 模式 ， 并 比较 这 两 种 方法 的 特性 。 


四 、 设 计 题 


1. 银行 系统 中 的 电子 银行 各 个 子 系统 是 相互 独立 的 ， 例 如 手机 银行 和 网 络 银行 ， 为 了 以 
现在 请 你 设计 一 套 登 录 系 统 ， 要 求 如 下 : 


后 更 好 的 发 展 ， 银 行 决定 对 这 些 子 系统 进行 整合 ， 


各 个 子 系统 具体 登录 过 程 不 一 样 ， 如 手机 银行 不 需 


要 证 


书 ， 仅 仅 需 要 用 户 名 和 密码 即 可 ， 而 


网 络 银行 需要 UKEY 或 者 文件 证 书 ， 但 登录 流程 都 是 一 致 的 ， 首 先 对 用 户 进行 验证 ， 验 证 通 


过 后 ， 显 示 欢 迎 界面 。 登 录 系 统 能 够 很 方便 地 接 入 更 多 的 电子 银行 的 形式 。 要 求 选用 合适 的 


设计 模式 ， 画 出 UML 图 和 系统 框架 图 。 


2. 请 设计 综合 对 帐 单 里 的 一 个 显示 模块 ， 此 模块 功能 是 获取 数据 库 里 的 数据 ， 在 界面 上 
当 数 据 库 里 的 数据 改变 时 ， 这 些 显 示 形 式 
也 会 立即 改变 ， 同 时 可 以 在 这 些 显示 形式 上 更 改 数据 后 ， 数 据 库 里 的 数据 会 立即 更 改 并 且 其 


进行 显示 ， 可 以 有 表格 、 柱 形 或 饼 状 等 显示 形式 ， 


他 显示 形式 也 需要 立即 改变 ， 要 求 选用 合适 的 设计 模式 ， 


画 出 UML 图 。 


某 顶 级 生活 消费 类 网 站 软件 工程 师 笔 试题 


1. 实现 对 一 组 无 序 的 字母 进行 从 小 到 大 排序 
字母 放 在 大 写字 母 前 。 要 求 时 间 复 杂 度 为 O(n)。 


(区 分 大 小 写 )， 


当 两 个 字母 相同 时 ， 小 写 


2. 狼 媛 之 家 有 个 传统 ， 就 是 每 个 月 都 要 组 织 专家 与 顾问 进行 一 次 团 建 活动 Team 


Building，TB)， 每 个 专家 或 顾问 都 可 以 带 家 属 参 加 。 


活动 内 容 除 了 吃喝 玩乐 之 外 ， 还 要 做 些 


互动 的 游戏 ， 需 要 从 专家 或 顾问 中 随机 选 出 儿 名 组 成 一 队 来 完成 游戏 ， 一 次 TB 活动 ， 
已 知 如 果 随 机 选取 3 位 专家 或 顾问 以 及 该 


有 20 个 人 ( 含 专家 、 顾 问 以 及 他 们 的 家 属 ) 参加 。 
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3 位 专家 或 顾问 的 家 属 ， 一 共有 220 种 组 合 。 请 问 如 果 每 次 随机 选取 4 个 专家 或 顾问 及 该 4 
位 专家 或 顾问 的 家 属 ， 会 有 多 少 种 组 合 ? 

3. 有 IN 个 磁盘 ， 每 个 磁盘 大 小 为 Di] (0，…，N-1)， 现 在 要 在 这 N 个 磁盘 上 “顺序 
分 配 ”M 个 分 区 ， 每 个 分 区 大 小 为 Pj] G=0，…，M-1)， 顺 序 分 配 的 意思 是 : 分 配 一 个 分 区 
P[] 时 ， 如 果 当 前 磁盘 剩余 空间 足够 ， 则 在 当前 磁盘 分 配 ; 如 果 不 够 ， 则 尝试 下 一 个 磁盘 ， 直 
到 找到 一 个 磁盘 D[itk] 可 以 容纳 该 分 区 , 分配 下 一 个 分 区 P[j+1] 时 , 则 从 当前 磁盘 D[i+g 的 剩 
余 空间 开始 分 配 , 不 再 使 用 D[itk] 之 前 磁盘 未 分 配 的 空间 ， 如 果 这 M 个 分 区 不 能 在 这 N 个 磁 
盘 完全 分 配 ， 则 认为 分 配 失败 。 请 实现 函数 is_allocable 判断 给 定 N 个 磁盘 (数组 D) 和 M 
个 分 区 (数组 P)， 是 否 会 出 现 分 配 失 败 的 情况 ? 举例 ;磁盘 为 [120，120，120]， 分 区 为 [60， 
60，80，20，80] 可 分 配 ， 如 果 为 [60，80，80，20，80]， 则 分 配 失败 。 

4. 请 实现 方法 : print_rotate_matrix(intmatrix,int n)， 该 方法 用 于 将 一 个 nxXn 的 二 维 数组 逆 
时 针 旋 转 45” 后 打印 ， 例 如 ， 下 图 显示 一 个 3X3 的 二 维 数组 及 其 旋转 后 屏幕 输出 的 效果 。 


3 . 
VA 2 3 逆 时 针 旋 转 45° 2 6 屏幕 输出 ， 6 
SS 一 一 -J1---5 一 -人 9- 一 1 5 9 
4 、 
5 FEED ms ， 。 
7 8 3、 7 7 


5. 给 定 正 整数 x， 定 义 函 数 AD)=1+x+x^2+x^A3+…+XAn (n 为 整数 且 过 0) ， 已 知 乘 运算 
的 时 间 远 大 于 加 运算 ， 输 入 x、n， 如 何 尽 可 能 快 地 求 出 A(n)? 
6. 请 用 两 个 队列 实现 栈 的 先进 后 出 的 操作 ， 和 希望 该 栈 的 push/pop 时 间 复 杂 度 尽量 小 。 请 
写 出 push/pop 的 代码 。 
7. 假设 有 一 个 中 央 调 度 机 ， 有 n 个 相同 的 任务 需要 调度 到 m 台 服 务 器 上 去 执行 ， 由 于 
每 台 服 务 器 的 配置 不 一 样 ， 因 此 ， 服 务 器 执行 一 个 任务 所 花费 的 时 间 也 不 同 。 现 在 假设 第 i 
个 服务 器 执行 一 个 任务 需要 的 时 间 为 { 癌 。 例 如 ， 有 2 个 执行 机 a 与 b， 执 行 一 个 任务 分 别 需 
要 7min 和 10min， 有 6 个 任务 待 调 度 。 如 果 平 分 这 6 个 任务 ， 即 a 与 b 各 3 个 任务 ， 则 最 短 
需要 30min 执行 完 所 有 任务 。 如 果 a 分 4 个 任务 ，b 分 2 个 任务 ， 则 最 短 28min 执行 完 。 
请 设计 调度 算法 , 使 得 所 有 任务 完成 所 需要 的 时 间 最 短 。 输入 m 台 服 务 器 , 每 台 机 器 处 理 
一 个 任务 的 时 间 为 t 昌 ， 完 成 n 个 任务 ， 输 出 n 个 任务 在 m 台 服 务 器 的 分 布 。int estimate_ 
process_ time(int[] t,int m,int n)。 
8. n(1,2,3,…,n) 个 元 素 有 NI 个 不 同 的 排列 , 将 这 nl 个 数控 字典 序 排列 , 并 编号 0,1,…,n!-1， 
每 个 编号 为 其 字典 序 的 值 ， 如 n=3 时 ， 字 典 排序 为 123，132，213，231，312，321， 这 6 个 
数 的 字典 序 分 别 为 0，1，2，3，4，5， 现 给 定 n， 请 输出 字典 序 为 k 的 排列 (0 志 k<n!)。 


某 知名 门户 网 站 软件 工程 师 笔 试题 


一 、 选 择 题 

1. 下 面 关于 java.lang.Exception 类 的 描述 中 ， 正 确 的 是 〈 ) 。 
A. 该 类 是 一 个 公共 类 B. 该 类 实现 了 Throwable 接口 
C. 该 类 是 Throwable 类 的 子 类 D. 该 类 可 以 序列 化 
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Java 程序 员 


下 面 不 是 Thread 类 的 方法 是 


)。 


A. run() B. start() C. exit() D. stop() 
3， 有 如 下 代码 : 
String strl = "abcd"; 
String str2 = "ab" + newString("cd"); 
System.err.println(strl == str2); 
上 面 程序 的 运行 结果 是 ( 
A. true B. false C. 不 确定 D. 编译 错误 


4. 有 如 下 代码: 


public static void main(String args[]) 


Thread t= new Thread() 
{ 
public void run() 
{ 
world(); 
} 
} 
trunO); 
System.out.print("hello"); 
} 
static void world() 
{ 
System.out.print("world"); 
} 


上 面 程序 的 运行 结果 是 〈 
A. helloworld 


)。 


B. worldhello 


C. A 和 B 都 有 可 能 


D. 都 不 输出 


5. GC 线程 (  ) 守护 线程 。 

A. 是 B. 不 是 C. 不 确定 
6. 下 列 属于 关系 数据 库 的 是 站 

A. Oracle B. MySQL C. MongoDB D. IMS 
7. 关键 字 volatile ( ) 保证 线程 安全 。 

A. 能 B. 不 能 C. 不 确定 
8. 下 列 关 于 Collection 类 结构 的 描述 中 ， 正 确 的 是 “〈 )。 

A. HashSet 继承 日 AbstractSet B. AbstractSet 继承 自 Set 

C. LinkedList 继承 自 List D. WeakMap 继承 自 HashMap 
9. 数字 0.6332 的 数据 类 型 是 〈 )。 

A. Float B. double C. float D. Double 
10. 使 1+1<i 的 数 (  )。 

A. 存在 B. 不 存在 C. 不 确定 
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11. 下 面 属于 面向 字符 的 输入 流 的 是 ( ”)。 


A. BufferedWriter B. ObjectInputStream 

C. FileInputStream D. InputStreamReader 
12. Java 接口 的 修饰 符 可 以 为 〈 )。 

A. static B. protected C. final D. abstract 
13. 不 通过 构造 方法 ( ”) 创建 对 象 。 

A. 可 以 B. 不 可 以 C. 不 确定 
14. 下 面 是 对 称 加 密 算 法 的 有 (  ”)。 

A. DES B. AES C. DSA D. RSA 
15. ArrayList al = new ArrayList(20) 中 的 list 扩 充 了 ( ) 次 。 

A. 0 B. 1 C3 2 D. 4 


16. 新 建 一 个 流 对 象 ， 下 面 代码 中 ， 描 述 错误 的 是 了 
A. new BufferedWriter(new File Writer("d.txt")); 
B. new BufferedReader(new FileInputStream("d.dat")); 
C. new ObjectInputStream(new FileInputStream("d.dat")); 
D. new GZIPOutputStream(new FileOutputStream("d.zip")); 
17. 有 如 下 代码 ; 


-> 


public class Test 


{ 
public static void hello() 
{ 
System.out.println("hello"); 
} 
public static void main(String[] args) 
{ 
((Test) null).hello(); 
} 


} 


上 面 程序 ( ) 正常 运行 。 
A. 不 能 B. 能 C. 不 确定 
18. f0 方 法 定义 如 下 所 示 ，try 中 可 以 捕获 三 种 类 型 的 异常 ， 如 果 在 该 方法 运行 中 产生 了 
一 个 IOException， 那 么 ， 此 时 的 输出 结果 是 《 3 


public void f() 
{ 
try 
{ 
// method that may cause an Exception 
} 
catch (java.io.FileNotFoundException ex) 
{ 
System.out.print("FileNotFoundException!"); 
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} 
catch (java.io.IJOException ex) 
{ 
System.out.print("IOException!"); 
} 
catch (java.lang.Exception ex) 
{ 
System.out.print("Exception!"); 
} 
} 
. IOException! 


FileNotFoundException!IOException! 


Om> 


IOException!Exception! 

D. FileNotFoundException!IOException!Exception! 
19. 在 Java 语 言 中 ， 打 印 语句 System.out.printn("3" 十 4) 的 输出 结果 是 ( 

A. 34 B. 7 C. 3 D. 4 
20. 有 如 下 代码 : 


)。 


public class Test 
public static void main(String[] args) 
{ 
String s; 
System.out.println("s=" 十 S); 
} 
} 


上 述 代码 的 输出 结果 是 六 

A. 代码 得 到 编译 ， 并 输出 “s=null” 

B. 代码 得 到 编译 ， 并 输出 “s=” 

C. 由 于 String s 没有 初始 化 ， 代 码 不 能 编译 通过 

D. 代码 得 到 编译 ， 但 捕获 到 NullPointException 异常 
21. 有 如 下 代码 : 


public class Test 
{ 
public static void main(String args[]) 
{ 
String str=new String("good"); 
char[] ch = {'a', 'b','c' }; 
change(str, ch); 
System.out.print(str + " and "); 
System.out.print(ch); 


} 


public static void change(String str, char ch[]) 
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str = "test ok"; 
ch[0] ='g; 


} 


上 述 代码 的 运行 结果 是 )。 

A. goodand abc B. goodand gbc 

C. test ok and gbc D. test ok and abc 
22. 要 从 文件 "file.dat" 中 读 出 第 10 个 字 节 到 变量 c 中， 下列 方法 正确 的 是 (  )。 
. FileInputStream in=new FileInputStream("file.dat"); in.skip(9); int c=in.read(); 


FileInputStream in=new FileInputStream("file.dat"); int c=in.read(); 
FileInputStream in=new FileInputStream("file.dat"); in.skip(10); int c=in.read(); 
. RandomAccessFile in=new RandomAccessFile("file.dat"); in.skip(9); int c=in.readByte(); 
23. 下 列 异 常 中 既是 检查 型 异常 ， 又 需要 在 编写 程序 时 声明 的 是 (。 ”)。 

A. NullPointerException B. ClassCastException 

C. IOException D. IndexOutOfBoundsException 
24. 有 如 下 代码 : 


DAW 


public static int fint 1) 
{ 
int result = 0; 
switch (i) 
{ 
case 1: 
result = result + 1; 
case 2: 
result = result +1*2; 
case 3: 
result = result +1* 3; 


} 


return result; 


} 


当 输 入 为 2 时 ， 返 回 值 是 〈 a 
A.0 B. 2 C. 4 D. 10 
25. 选项 ( ) 中 代码 可 以 替换 题目 中 /add code here 的 内 容 ， 同 时 不 产生 编译 错误 。 


public abstract class Example 
public int constInt = 5; 
/add code here 
public void method() 
{ 
} 
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} 
A. public abstract void method(float a); B. constInt= constInt + 7; 
D. public int method(); C. public abstract void method10 {}; 


26. 有 Shape 和 Circle 两 个 类 的 定义 ， 在 序列 化 一 个 Circle 的 对 象 circle 到 文件 时 ， 下面 
会 被 保存 到 文件 中 的 字段 是 )。 


class Shape 


了 
必 


public String name; 


} 
class Circle extends Shape implements Serializable 
{ 
private float radius; 
transient int color; 
public static String type = "Circle"; 
} 
A. name B. radius C. color D. type E. 都 不 会 


27. 下 面 是 People 和 Child 类 的 定义 ， 每 个 构造 方法 都 输出 编号 。 在 执行 new Child("e") 
时 ， 程 序 的 输出 结果 是 ( ”)。 


class People 
String name; 
public PeopleO 
System.out.print(] ); 


} 


public People(String name) 
System.out.print(2); 
this.name = name; 


} 
class Child extends People 
{ 
People father; 
public Child(String name) 
{ 
System.out.print(3); 
this.name = name; 
father = new People(name + ":F"); 
} 
public Child0 
{ 


System.out.print(4); 
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A. 312 B. 32 C. 432 D. 132 
二 、 简 答题 
1. 下 面 程序 的 运行 结果 是 什么 ? 


class Base 
{ 
public Base() 
{ 
System.out.println("Base"); 
} 
{ 
System.out.println("Tm Base class"); 
} 
static 
{ 
System.out.println("static Base"); 
} 
} 
public class Sub extends Base 
{ 
public Sub() 
{ 
System.out.println("Sub"); 
} 
{ 
System.out.println("Tm Sub class"); 
} 
static 
{ 
System.out.println("static Sub"); 
} 
public static void main(String[] args) 
{ 
new Sub(); 
} 
} 


三 、 系 统 设计 题 

微 博 中 的 url 往往 很 长 ， 发 送 前 要 转化 为 tinyurl。 

1. url 如 何 转 为 tinyurl 编码 ? 

2. 如 果 用 户 输 入 一 个 已 经 转换 过 的 url， 如 何 快速 定位 到 已 经 生成 了 的 tinyurl? 
3. 如 果 数 据 为 10 亿 条 ， 需 要 10 个 tinyurl 服务 器 ， 如 何 设计 ? 
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某 知名 互联 网 金融 企业 软件 工程 师 笔 试题 


一 、 不 定 项 选择 题 


1. 有 如 下 代码 : 


class A 
{ 
public int f(int a) 
{ 
return atl; 
} 
} 
class B extends A 
{ 
public int flint a, char c) 
{ 
return at+2; 
} 
public static void main(String[] args) 
{ 
B b=new BO; 
System.out.printin(b.f(0)); 
} 
} 
当 编 译 并 运行 上 面 程序 时 (文件 名 为 Testjava)， 输 出 结果 是 5 
A. 编译 错误 B. 运行 错误 C. 1 D. 2 
2. 有 如 下 代码 : 
public class Test 
{ 
public static void main(String argv[]) 
{ 
int[] arr = new int[5]; 
System.out.println(arr[S]); 
} 
} 
当 编 译 并 运行 上 面 程序 时 ， 输 出 结果 是 ( ”)。 
A. 编译 错误 B. 运行 错误 C. 输出 “null” D. 输出 0 


3. final、finally 和 finalize 三 个 关键 字 的 区 别 是 〈 5 
A. finally 用 在 异常 处 理 中 ， 提 供 finally 块 来 执行 任何 清除 操作 
B. final 可 以 修饰 类 、 方 法 和 变量 
C. finalize 是 一 个 方法 名 ， 在 垃圾 回收 器 将 对 象 从 内 存 中 清除 出 去 之 前 做 一 些 必要 的 
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清理 工作 
D. finally 和 finalize 都 是 用 于 异常 处 理 的 方法 
4. 有 如 下 代码 : 


public class Test extends Thread 


{ 
public static void main(String argv[]) 
{ 
Test b = new Test(); 
b.run(); 
} 
public void start() 
{ 
for (inti= 0;1i< 10;1i++) 
{ 
System.out.printin("Value of 1 = " +); 
} 


当 编 译 并 运行 上 面 程序 时 ， 输 出 结果 是 ( ”)。 
A. 编译 错误 ， 指 明 run 方法 没有 定义 B. 运行 错误 ， 指 明 run 方法 没有 定义 
C. 编译 通过 并 输出 0 一 9 D. 编译 通过 但 无 输出 
5. 在 Java 语言 中 ， 如 果 父 类 中 的 某 些 方法 不 包含 任何 逻辑 ， 并 且 需 要 由 子 类 
该 使 用 关键 字 (  ”) 来 声明 父 类 的 这 些 方法 。 
A. static B. final C. abstract D. void 
6. 有 如 下 代码 : 


| 中 


E 写 ， 应 


public class Test 
{ 
public static void main(String argv[]) 
{ 
Test h = new Test(); 
} 
protected Test() 
{ 
for(int 1 =0; i1 <10; 1++) 
{ 
System.out.printlIn(); 
} 
} 
} 


当 编 译 并 运行 上 面 程序 时 ， 输 出 结果 是 ( 。”)。 
A. 编译 错误 ， 构 造 方法 不 能 被 声明 为 protected 
B. 运行 错误 ， 构 造 方法 不 能 被 声明 为 protected 
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C. 编译 并 运行 输出 0 一 10 
D. 编译 并 运行 输出 0 一 9 
7. 下 列 关 于 String 和 数组 的 描述 中 ， 正 确 的 是 〈 多 


A. String 有 length 属性 B. String 有 length() 方 法 
C. 数组 有 length 属性 D. 数组 有 length0 方 法 


8. 有 如 下 代码 : 


public class Test 


| 


public static void stringReplace(String text) 


{ 


text=text+"c"; 


} 


public static void bufferReplace(StringBuffer text) 


{ 
text=text.append("c"); 
} 
public static void main(String args[]) 
{ 
String textString=new String("ab"); 
StringBuffer textBuffer=new StringBuffer("ab"); 
stringReplace(textString); 
bufferReplace(textBuffer); 
System.out.println(textString+textBuffer); 
} 
} 
当 编 译 并 运行 上 面 程序 时 ， 输 出 结果 是 ( ”)。 
A. 编译 并 运行 输出 ab 。 ab B. 编译 并 运行 输出 abc abc 
C. 编译 并 运行 输出 ab abc D. 编译 并 运行 输出 abc ”ab 


9. 有 如 下 代码 ; 


String a=” Hello”; 
String b=” Hello”; 
String c=new String(” Hello”); 
String d=new String(” Hello”); 


以 上 表达 式 中 ， 返 回 值 为 真 的 有 (  ”)。 

A. a 一 B. a== CGC. C== 

D. a.equals(b) E. a.equals(c) F. c.equals(d) 
10. 有 如 下 代码 : 


public class Test 


{ 
static int 1; 


public int test() 
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{ 
计 十 ; 
return i; 
} 
public static void main(String args[]) 
{ 
Test test = new Test(); 
test.test(); 
System.out.println(new Test().test()); 
} 


} 


当 编 译 和 运行 上 面 程序 时 ， 下 面 选项 中 ， 描 述 正确 的 是 ( )。 
A， 编译 并 输出 0 B. 编译 错误 C. 编译 并 输出 null 


11. 以 下 关于 线程 的 描述 中 ， 错 误 的 是 )。 
A. sleep 方法 必须 写 在 同步 方法 或 同步 块 
B. wait 方法 执行 时 会 释放 对 象 锁 
C. sleep 方法 执行 时 会 释放 对 象 锁 
D. wait 方法 必须 写 在 同步 方法 或 同步 块 中 

12， 有 如 下 代码 : 


D. 


运行 错误 


class A 
{ 
public A() 
{ 
System.out.println(“A’”’); 
} 
} 
class B extends A 
| 
public B() 
{ 
System.out.println(“B’’); 
} 
public static void main(String[] args) 
{ 
b=new B(); 
} 


} 


上 述 程序 将 (。” ”)。 


A. 不 确定 B. 通过 编 
C. 通过 编译 ， 输 出 为 B D. 通过 编 


13. 有 如 下 代码 : 


i 译 ， 输 出 为 AB 


译 ， 运 行 时 错误 


public class Test 
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{ 


} 


static int i; 
public int test() 
{ 
1++; 
return i; 


} 


public static void main(String args[]) 


Testtest = new Test(); 
test.test(); 


System.out.printIn(new Test().test()); 


编译 运行 后 ， 输 出 结果 是 (  ”)。 


A. 


0 B. 1 


14. 有 如 下 代码 : 


class A extends B 


{ 


} 


public A() 
{ 

superQ; 
} 
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以 下 关于 super 的 用 法 的 描述 中 ， 正 确 的 是 (  ”)。 


A. 
B. 
GC; 
D. 


用 来 调用 类 A 中 定义 的 super0) 方 法 
用 来 调用 类 B 中 定义 的 super0 方 法 
用 来 调用 类 B 中 的 无 参 构造 方法 
用 来 调用 类 B 中 第 一 个 出 现 的 构造 方法 


15. Thread 类 中 本 身 的 方法 〈 不 包括 继承 ) 有 ( )。 


A. 


16. 下 面 关 于 类 和 接口 的 描述 中 ， 正 确 


. 类 不 能 被 private 修饰 


7: 


start() B. sleep(long mi) 


C. notify() 


的 是 (  )。 


接口 中 可 定义 变量 ， 并 且 变 量 的 值 不 能 修改 


类 可 以 被 protected 修饰 
接口 不 能 实例 化 


四 关于 关键 字 synchronized 的 


pmy> 志 SPgy> 


述 


h， 错 误 的 是 ( 。。)。 
保证 两 个 或 多 个 进程 同时 启动 和 结束 
只 证 任何 时 候 只 有 一 个 线程 访问 一 个 方法 或 对 象 


允许 两 个 进程 并 行 运行 但 其 之 间 相 互通 信 
保证 两 个 或 多 个 线程 同时 启动 和 结束 


D. wait() 


18. 


19. 


20. 


21: 


| 
4 
加 


下 列 关 于 abstract 的 描述 中 ， 正 确 的 是 ) 
A. abstract 修饰 符 可 以 修饰 属性 、 方 法 和 类 
B. 声明 抽象 方法 ， 大 括号 可 有 可 无 

C. 抽象 方法 的 body 部 分 必须 用 一 对 大 括号 {} 
D. 声明 抽象 方法 不 可 写 出 大 括号 
下 面 关 于 网 络 通信 的 描述 中 ， 正 确 的 是 

A. TCP/IP 协议 是 一 种 不 可 靠 的 网 络 通信 协议 

B. TCP/IP 协议 是 一 种 可 靠 的 网 络 通 信 协 议 

C. UDP 协议 是 一 种 可 靠 的 网 络 通信 协议 

D. UDP 协议 是 一 种 不 可 靠 的 网 络 通信 协议 

在 Java 语言 中 ， 下 面 关于 抽象 类 的 描述 中 ， 正 确 的 是 

A. 声明 抽象 类 必须 带 有 关键 字 abstract 

B. 如 果 一 个 类 中 有 一 个 方法 被 声明 为 抽象 的 ， 那 么 这 个 类 必须 是 抽象 类 
C. 抽象 类 的 方法 都 必须 是 抽象 的 

D. 抽象 类 可 以 被 实例 化 

有 如 下 代码 : 


public class Test 
{ 
public int f() 
{ 
return 1 % 5$; 
} 
public static void main(String[] args) 
{ 
System.out.printin(f()); 
} 
} 


编译 运行 结果 是  )。 


A. 编译 错误 B. 运行 错误 
C. 正常 运行 ， 输 出 1 D. 正常 


22. 将 对 象 序 列 化 ， 要 实现 的 接口 是 (  )。 


A. Runnable B. Cloneable C. Serializable D. Comparator 


23. 有 如 下 代码 : 


public class Test 
{ 
public static String output = ""; 
public static void foo(int 1) 
{ 
try 
{ 
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if (i==1) 
{ 
throw new Exception(); 
} 
output += "1"; 
} 
catch (Exception e) 
{ 
output + 一 "2 ; 
return; 
} 
finally 
{ 
output += "3"; 
} 
output + 一 "4"; 
} 
public static void main(String args[]) 
{ 
foo(0); 
foo(1); 
System.out.println(output); 
} 
} 
上 述 代码 的 输出 结果 为 〈 乱 
A. 134 B. 1234 C. 134234 D. 13423 
24. 在 Java 语言 中 ， 位 于 集合 框架 的 顶层 的 接口 是 (  )。 
A. Collection B. Collections C. List D. Iterator 
25. 在 Java 语言 中 ， 下 列 不 能 派生 出 子 类 的 类 为 (  )。 
A. public class Test{} B. class Test{} 
C. abstract class Test{} D. final class Test{} 
26. 以 下 可 以 启动 一 个 线程 的 方法 是 (  )。 
A. start() B. run() C. begin() D. notify() 
27. 在 Java 语言 中 ， 己 定义 两 个 接口 B 和 C， 要 定义 一 个 实现 这 两 个 接口 的 类 ， 以 下 语 
人 句 正确 的 是 (  )。 
A. interface A implements B,C B. interface A extends B,C 
C. class A implements B,C D. class A implements B,implements C 


28. 在 Java 语言 中 ， 以 下 定义 数组 的 语句 正太 


外 的 是 ( 。”)。 


)。 


A. intt[10]=new int[]; B. chara[ll="abe"; 

C. intt[j=new int[20]; D. double d=new double[20]; 
29. 在 Java 语言 中 ， 如 果 需 要 编写 一 个 多 线程 程序 ， 可 以 使 用 的 方法 是 

A. 实现 Runnable 接口 B. 扩展 类 Thread 
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其 矶 所 
C. 扩展 类 Runnable D. 实现 接口 Thread 
30. 在 集合 框架 中 ， 要 实现 对 集合 里 的 元 素 进行 自 定 义 排序 ， 要 实现 的 接口 是 (  )。 
A. Cloneable B. Thread C. Serializable D. Comparator 


31. 有 如 下 代码 : 


class Super 


{ 

protected float getNum() {return 2.0f;} 

} 

public class Sub extends Super 

{ 
1/(1) 

} 

下 面 可 放 在 (1) 处 的 代码 有 ( ”)。 
A. float getNum(){return 1.0f;} B. public void getNum(O){} 


C. private void getNum(double d){} DD. public double Getnum(){return 5.0d;} 
E. public float getNum(){return 1;} 
32. 给 定 一 个 Java 程序 的 main 方法 的 代码 片段 如 下 : 


try 

{ 
PrintWriter out = new PrintWriter(new FileOutputStream("d:/a.txt")); 
String name="chen"; 
out.print(name); 

} 


catch(Exception e) 


{ 
System.out.printin(" 文 件 没有 发 现 ! "); 


} 


假如 d 目录 下 不 存在 a.txt 文件 ， 现 运行 该 程序 ， 下 面 的 结果 正确 的 是 3 
A. 将 在 控制 台 上 打印 : "文件 没有 发 现 ! " 
B. 运行 后 生成 abc.txt， 该 文件 内 容 为 : chen 
C. 运行 后 生成 abc.txt， 但 该 文件 中 可 能 无 内 容 
D. 正常 运行 ， 但 没有 生成 文件 abc.txt 
33. 下 面 直接 继承 自 Collection 接口 的 接口 有 a 
A. List B. Map GC, Set D. HashMap 
34. 以 下 关于 HashMap 和 HashTable 的 描述 中 ， 正 确 的 是 ( js 
A. HashTable 不 允许 null 键 或 值 
B. HashTable 类 不 是 同步 的 ， 而 HashMap 类 是 同步 的 
C. 都 实现 了 Map 接口 
D. HashMap 不 允许 null 键 或 值 
35. 下 面 关 于 构造 方法 的 描述 中 ， 正 确 的 是 b 


工 
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A. 构造 方法 不 能 被 重 写 
C. 构造 方法 不 能 被 重 载 
36. 有 如 下 代码 : 


B. 构造 方法 不 能 被 继承 
D. 构造 方法 不 能 声明 为 private 


public class TestException 


{ 
public static void main(String[] args) 
try 
System.out.println("hello "); 
System.exit(0); 
} 
finally 
System.out.println("world"); 
} 
} 


} 


以 上 程序 的 输出 结果 为 ) 
A. hello B. world C. helloworld 
37. 有 如 下 代码 : 


public class TestException 


{ 
public static void main(String[] args) 
{ 
int a[] = {0,1,2,3,4}; 
int sum=0; 
try 
{ 
for(int 1=0;i<6;i++) 
{ 
Sum+=alj]; 
} 
System.out.println("sum="+sum); 
} 
catch(java.lang.ArrayIndexOutOfBoundsException e) 
{ 
System.out.printIn(" 数 组 下 标 越界 "); 
} 
finally 
{ 
System.out.println(" 程 序 结束 "); 
} 
} 
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县 二 类 后 
} 
以 上 程序 的 输出 结果 为 
A. 10 程序 结束 B. 10 数组 下 标 越界 程序 结束 
C. 数组 下 标 越界 程序 结束 D. 程序 结束 


38. 有 如 下 代码 : 


public class Test 


{ 


public Test(int x,int y,int 2z){} 


} 


以 下 选项 中 ， 重 载 了 Test 构造 方法 的 有 (  ”)。 
A. Test 0 分 
. protected int Test (){} 


B 
C. private Test(int Zint y,byte 2z){} 
D. public void Test(byte x,byte ybyte 2z){} 
E. public Object Test(int x,int yint 2){} 
39. 有 以 下 代码 : 


package com; 
public class Test 
{ 
public static void main(String[] args) 
{ 
Test t= new Test(); 
1 
3 


} 


下 面 可 以 获得 Class 对 象 的 有 六 
A. Class ¢ = test.class; B. Class c = new Class(); 
C. Class ¢ = Test.class; D. Class c = test.getClass(); 
E. Class c = Class.forName(‘com.Test’); F. Class ¢ = ClassforName( Test’); 
40. 下 列 选项 中 ， 能 用 来 修饰 interface 方法 的 有 (  ”)。 
A. private B. public 
C. protected D. finalE、 不 加 修饰 符 
二 、 简 答题 
1.，fail-fast 和 fail-safe 迭代 器 的 区 别 是 什么 ? 
2. 对 于 一 些 敏感 的 数据 (例如 密码 )， 为 什么 使 用 字符 数组 存储 比 使 用 String 更 安全 ? 
3. 如 何 捕获 一 个 线程 抛 出 的 异常 ? 
4. 一 个 人 存在 于 社区 中 ， 会 有 各 种 各 样 的 身份 ， 和 不 同 的 人 相处 会 有 不 同 的 关系 。 请 自 
行 设计 数据 库 〈 表 结构 ， 个 数 不 限 )， 保 存 一 个 人 的 名 字 、 关 系 〔 包 括 父 亲 、 朋 友 们 )， 并 使 
用 尽 可 能 少 的 时 间 空 间 开 销 组 织 好 每 个 人 和 其 他 人 的 关系 ， 组 织 好 后 尝试 取出 一 个 人 的 关系 
结构 ， 其 中 涉及 的 SQL 语句 请 详细 写 出 ， 涉 及 的 数据 结构 、 数 据 组 织 形 成 也 请 描述 清楚 ， 代 
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码 可 以 用 伪 代 码 或 你 熟悉 的 任何 代码 给 出 。 
5， 段 页 式 虚拟 存储 管理 方案 的 特点 是 什么 ? 


国内 某 知名 网 络 设备 提供 商 软件 工程 师 笔试 题 


单 选 题 
1. 下 面 关 于 main 方法 的 方法 头 的 定义 中 ， 合 法 的 是 )。 
A. public static void main() B. public static void main( String args[] ) 


C. public void main(Strng arg[]) D. public static int main(String [arg) 
2. 编译 Java 应 用 程序 源 文 件 将 产生 相应 的 字 节 人 码 文件 ， 这 些 字 节 码 文件 的 扩展 名 为 


A. .class B. .java C. .html D. .exe 
3. 如 果 x=1,y=2,z=3， 则 表达 式 y+=z--/++x 的 值 是 (  )。 
A. 3 B. 3.5 C. 4 D. 4.5 
4. 在 Applet 子 类 中 ， 一 般 需 要 重 载 父 类 的 ( ””) 方法 来 完成 一 些 画 图 操作 。 
A. stop() B. start() C. init() D. paint() 
5. 以 下 不 允许 作为 类 及 类 成 员 的 访问 控制 符 的 是 ( ””)。 
A. private B. public C. static D. protected 


二 、 填 空 题 
1. 如 果 一 个 Java Applet 源 程序 文件 只 定义 有 一 个 类 ， 该 类 的 类 名 为 MyApplet， 那 么 类 
MyApplet 必须 是 ( ) 类 的 子 类 ， 并 且 存 储 该 源 程序 文件 的 文件 名 为 《 )。 
2. 在 Java 语言 中 ，char 型 采用 Unicode 编码 方案 ， 每 个 Unicode 码 占 用 ( ) 字 节 内 
存 空间 ， 这 样 ， 无 论 是 中 文字 符 还 是 英文 字符 ， 都 是 占用 ( ) 字 节 内 存 空 间 。 
3. 开发 与 运行 Java 程序 的 三 个 主要 步骤 为 〈 )、( ) 和 ( ks 
4. 如 果 一 个 Java Applet 程序 文件 中 定义 有 4 个 类 , 则 使 用 Sun 公司 的 JDK 编译 器 ( ) 
编译 该 源 程序 文件 将 产生 ( ) 个 文件 名 ， 与 类 名 相同 而 扩展 名 为 〈 ) 的 字 节 码 文件 。 
5. 假设 二 2， 那 么 表达 式 (i++)/3 的 值 为 《 局 
6. 假设 x=5, y=6， 则 x<y 和 x>=y 的 逻辑 值 分 别 为 ( ) 和 ( )。 
yA ) 方法 是 一 种 仅 有 方法 头 ， 没 有 具体 方法 体 和 操作 实现 的 方法 ， 该 方法 必须 在 
] 象 类 之 中 定义 。( ) 方法 是 不 能 被 当前 类 的 子 类 重新 定义 的 方法 。 
38. 创建 一 个 名 为 MyPackage 的 包 的 语句 是 ( ””)， 该 语句 应 该 放 在 程序 的 位 置 为 ( ” )。 
9. 设 有 数组 定义 ， int arr[ ] = { 10 , 20 , 30 , 40 , 50 , 60 , 70};， 则 执行 以 下 几 个 语句 后 的 
输出 结果 是 )。 


NS 


int s=0; 

for(int 1=0;1<arrlength;i++) 
if (1%2==0) 
{ 


s+= arr[i|; 


} 
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System.out.println( s ); 
10. 在 Java 程序 中 ， 通 过 类 的 定义 只 能 实现 ( ) 重 继 承 ， 但 通过 接口 的 定义 可 以 实 
现 ( ) 重 继 承 关 系 。 
三 、 写 出 下 列 程序 完成 的 功能 
1.， 代码 如 下 : 


| 由 


import java.io.*; 
public class Test 
{ 
public static void main(String args[]) 
{ 
int n=5; 
int a[] = new int[n]; 
for (inti=0;1<n;1++) 
try 
{ 
BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); 
alji] = Integer.parseInt(br.readLine()); 
} 
catch (IOException e) {} 
for (inti=n-1;1i>=0;1-) 
System.out.print(a[i] + " "); 


= 一 


} 


2. 代码 如 下 : 


public class Test 


{ 
public static void main(String args[]) 
{ 
double sum = 0.0; 
for (inti= 1;1<= 100; i++) 
sum += 1.0 / (double) i; 
System.out.println("sum=" + sum); 
} 


3， 代码 如 下 : 


public abstract class Test 


‘ 


long aver = 0; 

long max = 0; 

long min = 0; 

intn=0; 

protected abstract void timeConsumingOperation(); 
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public void calculate(int n) 
{ 
long start; 
long interval; 
long sum = 0; 
this.n =n; 
for (inti=0;1<n;1++) 
{ 
start = (new java.util.Date()).getTime(); 
timeConsumingOperation(); 
interval = (new java.util.Date()).getTime() - start; 
sum += interval; 
if (interval > max) 
max = interval; 
if (i== 0) 
min = interval; 
else if (interval < min) 
min = interval; 
} 
aver= sum /n; 


System.out.println("aver:\t" + aver + " miliSeconds"); 


System.out.println("max:t" + max + " miliSeconds"); 
System.out.println("min:\t" + min + " miliSeconds"); 


} 


四 、 写 出 下 面 程序 的 运行 结果 
1. 代码 如 下 : 


public class Test 
{ 
public static void main(String args[]) 
{ 
String strl = " Hello"; 
String str2 = " world"; 
System.out.println(new Str(str1, str2)); 
System.out.println(str2 ); 
} 
} 
class Str 
{ 
String sl; 
String s2; 
Str(String strl, String str2) 
{ 
sl = strl; 
S2 = str2; 
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str2 += strl; 
} 
public String toString() 
{ 
return sl 十 S2; 
} 


} 


2. 代码 如 下 : 


public class Ex 
{ 
public static void main(String[] args) 
{ 
Fx f=new Fx(9); 
} 
Ex() 
{ 
System.out.println("Ex,no-args"); 
} 
Ex(int 1) 
{ 
System.out.println("Ex,int"); 
} 
} 
class Fx extends Ex 
{ 
Fx() 
{ 
super(); 
System.out.println("Fx,no-args"); 
} 
Fx(int 1) 
{ 
this(); 
System.out.println("Fx,int"); 
} 
} 


国内 某 顶 级 手机 制造 商 软 件 工程 师 笔 试题 


一 、 选 择 题 


1. 有 如 下 代码 : 


public class Test 


{ 


public static void changeStr(String str) 
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str = "world"; 

} 

public static void main(String[] args) 

{ 
String str = "hello"; 
changeStr(str); 
System.out.println(str); 

} 

} 
程序 的 输出 是 ( ” )。 
A. hello B. world C. hello world D. world hello 


2. 有 如 下 代码: 


public class Test 


{ 


static boolean fchar c) 
System.out.print(c ); 
return true; 


} 


public static void main(String[] argv) 
{ 
inti= 0; 
for (f(A'"); f(B'") && (i < 2); f('C")) 
{ 
i1++; 
frDy: 


} 


显 序 的 输出 是 ( 。”)。 
A. ABDCBDCB B. ABDCBCBD 


3. 有 如 下 代码 : 


=n 


C. ABCDDCBA 


D. ABCDABCD 


class A 
{ 


protected int method (int a, int b) { return 0; } 


} 


以 下 在 A 的 子 类 中 使 用 正确 的 是 ( )。 
A. public int method (int a, int b) { return 0; } 
B. private int method (int a, int b) { return 0; } 
C. private int method (int a, char b) { return 0; } 
D. static protected int method (int a, int b) { return 0; } 
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E. public short method (int a, int b) { return 0; } 
4. 有 如 下 代码 : 


1) public class Outer{ 

2) public void someOuterMethod() { 
3) // Line 3 

2 } 


5) public class Inner{} 
6) public static void main( String[]argv ) { 


7) Outer o = new Outer(); 
8) /Line 8 
9) } 
10)} 
以 下 实例 化 内 部 类 的 方法 中 ， 使 用 正确 的 是 ( ” ”)。 
A. new Inner();// At line 3 了 .new Inner();// At line 8 
C. new Outer.Inner(); // At line 8 D. new o.Inner();// Atline 8 


5. 以 下 可 以 替换 URL 中 的 session ID 的 方法 是 ( Ds 
A. HttpServletRequest 接口 的 encodeURL 方法 
B. HttpServletResponse 接口 的 encodeURL 方法 
C. HttpServletRequest 接口 的 rewriteURL 方法 
D. HttpServletResponse 接口 的 rewriteURL 方法 

6. 以 下 方法 中 ， 等 价 的 两 个 是 js 
A. <%= YoshiBean.getProperty("size")%> 

. <%= YoshiBean.getSize()%> 

. <%= YoshiBean.size%> 


. <jsp:getProperty id="YoshiBean" param="size"/> 


<jsp:getProperty name=" YoshiBean" param="size"/> 
<jsp:getProperty id="YoshiBean" property="size"/> 


. <jsp:getProperty name="YoshiBean" property="size"/> 


TOO 


二 、 简 答题 

1. 简要 介绍 对 Struts 的 体系 结构 的 理解 。 

2. XML 包括 哪些 解释 技术 ? 它们 有 什么 区 别 ? 

3. JSP 有 哪些 内 置 对 象 和 动作 ? 

4. SELECT * FROM TABLE 和 SELECT * FROM TABLEWHERE NAME LIKE '%%' 
AND ADDR LIKE '%%'AND (1 ADDR LIKE '‘%%' OR 2 ADDR LIKE '%%'OR 3 ADDR LIKE 
'%%' OR 4 ADDR LIKE '%%' ) 的 检索 结果 为 何不 同 ? 

5. 定义 有 表 结 构 如 下 所 示 : 

(1) 表 名 : g_cardapply 

字段 (字段 名 /类 型 /长 度 ) : 


gapplyno varchar 8; /申请 单 号 〈 关 键 字 ) 
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2 applydate ”bigint ”8; /申请 日 期 
& state varchar ”2; /申请 状态 


(2) 表 名 : g cardapplydetail 
字段 (字段 名 /类 型 /长 度 ): 


g_applyno varchar ”8; // 申 请 单 号 (关键 字 ) 
g_name varchar ”30; /申请 人 姓名 

& idcard varchar ”18; /申请 人 身份 证 号 
g_state varchar ”2; // 申 请 状态 


其 中 ， 两 个 表 的 关联 字段 为 申请 单 号 。 


题 
1) 查询 身份 证 号 码 为 612301430103082 的 申请 日 期 。 

2) 查询 同一 个 身份 证 号 码 有 两 条 以 上 记录 的 身份 证 号 码 及 记录 个 数 。 

3) 将 身份 证 号 码 为 612301430103082 的 记录 在 两 个 表 中 的 申请 状态 均 改 为 15。 
4) 删除 g_cardapplydetail 表 中 所 有 姓 张 的 记录 。 


某 顶 级 大 数据 综合 服务 提供 商 软 件 
工程 师 笔 试题 


一 、 选 择 题 
1. 有 如 下 定义 : Short a =128; byte b =(byte)a;， 则 经 过 强制 类 型 转换 以 后 ， 变 量 a 和 变量 
b 的 值 分 别 为 《 )。 
A. 128, —128 B. 128, 127 C. 128, 128 D. 编译 错误 
2. 如 果 用 数组 S[0...n] 作 为 两 个 栈 S1 和 S2 的 存储 结构 ， 对 任何 一 个 栈 ， 只 有 当 S 全 满 
时 才 不 能 做 入 栈 操 作 ， 那 么 为 S1、S2 这 两 个 栈 分 配 空间 的 最 佳 方案 是 ( )。 
A. S1 的 栈 底 位 置 为 0，S2 的 栈 底 位 置 为 n+1l 
B.S1 的 栈 底 位 置 为 1，S2 的 栈 底 位 置 为 w2 
C.S1 的 栈 底 位 置 为 0，S2 的 栈 底 位 置 为 2 
D. S1 的 栈 底 位 置 为 1，S2 的 栈 底 位 置 为 n+1l 


3. 对 于 Java 语言 中 的 Daemon 线程 ，setDaemon 设置 必须 要 ( ba 
A. 在 start 之 后 B. 在 start 之 前 
C. 前 后 都 可 以 D. 前 后 都 不 可 以 


4. 有 以 下 一 个 对 象 : 


import java.io.Serializable; 
public class DataObject implements Serializable 
1 

private static int 1=0; 


private String word=""; 


public void setWord(String word) 
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县 A 所 

{ 

this.word=word; 
} 
public void setI(int 1) 
{ 

DataObject.i =i; 
} 

} 


创建 一 个 如 下 方式 的 DataObject: 


DataObject object = new DataObject(); 
object.setWord(“123”); 
object.setI(2); 


将 此 对 象 序列 化 文件 ， 并 在 另 一 个 JVM 
DataObject 对 象 中 的 word 和 i 的 值 分 别 是 〈 和 


读 取 文件 ， 进 行 反 序列 化 ， 此 时 读 出 的 


A. “”, 2 B. “”, 0 CC “123”; 2 D. “123”, 0 
5. 下 面 不 是 标准 的 Statement 类 的 是 )s 

A. Statement B. CallableStatement 

C. PreparedStatement D. BatchedStatement 
6. 下 面 类 中 可 以 被 继承 的 是 ( 法 

A. Number B. Thread C. Double 

D. Math E. ClassLoader 


7. 下 面 有 关 forward 和 redirect 的 描述 中 ， 正 确 的 是 《 )。 

A. forward 是 内 部 重 定向 ，redirect 是 外 部 重 定向 

B. forward 是 服务 器 将 控制 权 转 交 给 另外 一 个 内 部 服务 器 对 象 ， 由 新 的 对 象 来 全 权 

负责 响应 用 户 的 请 求 

C. 执行 forward 时 ， 浏 览 器 不 知道 服务 器 发 送 的 内 容 是 从 何 处 来 ， 浏 览 器 地 址 栏 中 
还 是 原来 的 地 址 

D. 执行 redirect 时 ， 服 务 器 端 告诉 浏览 器 重新 去 请 求 地 址 
8. 有 以 下 代码 : 


A 


String s="hello"; 
String t="hello"; 
char c[] ={'h','e',l',']','o'}; 
下 列 选 项 中 ， 返 回 值 为 false 的 语句 是 (  )。 
A. s.equals(t); B. t.equals(c); 
C. tequals(new String(“hello’)); D. s==t; 


二 、 简 答题 
1. Java 语言 具有 哪些 特点 ? 


2. 下面 这 段 代码 在 一 些 特 定 的 情况 下 有 问题 ， 请 指出 并 改正 。 
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import java.util.List; 

import java.util.ArrayList; 

public class MyStack 

{ 
private List<String> stack=new ArrayList<String>(); 
public synchronized void push(String value) 


{ 
synchronized(this) 
{ 
stack.add(value); 
notify(; 
} 
} 
public synchronized String pop() throws InterruptedException 
{ 
synchronized(this) 
{ 
if(stack.size()<=0) 
{ 
wait(); 
} 
return stack.remove(stack.size()-1); 
} 
} 


} 


3. 下 面 代码 输出 的 结果 是 (  ”)。 


class Base 
{ 
int num = 1; 
public Base() 
{ 
this.print(); 
num = 2; 
} 
public void print() 
{ 


System.out.println("Base.num = " + num); 


} 


class Sub extends Base 


{ 
int num = 3; 
public Sub() 
{ 


this.print(); 
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圈 


如 何 角 
JDBC 事务 隔离 级 别 有 几 种 ? 


2 D 门 和 由 


Web 服务 器 与 Web 应 月 


服务 器 有 什么 


在 HashTable、Vector、TreeSet 和 LinkedList 


num = 4; 
} 
public void print() 
{ 
System.out.println("Sub.num = " + num); 
} 
} 
public class Test 
public static void main(String[] args) 
{ 
Base b= new Sub(); 
System.out.println(b.numy); 
} 
} 
请 给 出 你 最 熟悉 的 三 个 设计 模式 的 类 图 。 


EE 使 JVM 的 堆 、 栈 和 持久 代 (perm) 发 生 内 存 溢出 ? 


P， 


哪个 容器 是 线程 安全 的 ? 


区 别 ? 


某 著 名 社交 类 上 市 公司 软件 工程 师 笔 试题 


、 填 空 题 
1. 面向 对 象 的 三 大 特性 是 )、 
2. JSP 内 置 对 象 及 方法 有 request、( 
即 可 ) 


( 


3. List、Set 和 Map 是 否 继承 E 
4. 数据 库 的 事务 特征 分 别 是 
5 
1 


)、. 


， 向 数据 库 表 上 
、 选 择 题 


， 对 于 abstract 声明 的 类 ， 下 面 说 法 正 胡 


Collection 接口 ? 
增加 一 列 的 SQL 语法 是 〈 


外 的 


) 和 ( 
)、( 


)s 


J ) 和 ( ) 等 。( 列 出 4 个 


《 


) 站 


A. 不 可 以 被 继承 
D. 只 能 被 继承 
2. 有 如 下 代码 : 


E. 可 以 被 抽 


B. 可 以 实例 


化 
象 类 继承 


C. 子 类 为 abstract 


Integer i=new Integer(4); 
Long l=new Long(4); 
Double d=new Double(4.0); 


下 面 选项 中 ， 返 回 结果 为 true 的 是 
Ai 一 卫 ，d 一 
E. d.equals(]) F. i.equals(]) 


) 
GC; 
G. 


D. 
l.equals(4L) 


i== i.equals(d) 


) 


77 


Java 程序 员 面试 笔试 真题 


3. 有 如 下 代码 : 


int x=8,y=2,2; 
X=++X*y; 
Z=X/y++; 


在 执行 完 后 ， 变 量 x 和 变量 y 的 值 分 别 是 (  )。 
A. 16, 3 B. 18, 4 C. 18, 2 D. 18, 3 
4. 当 线 程 1 使 用 某 个 对 象 ， 而 此 对 象 又 需要 线程 2 修改 后 才能 符合 线程 1 的 需要 ， 这 时 
线程 1 就 要 等 待 线程 2 完成 修改 工作 ， 这 种 现象 称 为 ( )。 
A. 线程 的 同步 B. 线程 的 调度 C. 线程 的 就 绪 ” D. 线程 的 互 斥 
5. 在 Java 程序 中 定义 一 个 类 ， 类 中 有 一 个 没有 访问 权限 修饰 的 方法 ， 下 面 关 于 此 方法 
的 描述 中 ， 正 确 的 是 (  ”)。 


A. 类 外 的 任何 方法 都 不 能 访问 它 B. 类 外 的 任何 方法 都 能 访问 它 

C. 类 的 子 类 和 同 包 类 能 访问 它 D. 只 有 类 和 同 包 类 才能 访问 它 
三 、 问 答题 
1. 在 inti=0; 二 it+; 语 句 中 ， 二 it+ 是 线程 安全 的 吗 ? 如 果 不 安全 ， 请 说 明 上 面 操作 在 JVM 


中 的 执行 过 程 ， 为 什么 不 安全 ? 说 出 JDK 中 哪个 类 能 达到 以 上 程序 的 效果 ， 并 且 是 线程 安全 
而 高 效 的 ， 简 述 其 原理 。 

2. 定义 有 数组 int a[200] = { 1，2，2，3，…}， 数 组 元 素 都 为 正 整数 ， 且 afi+1] >= af[j]， 
请 快速 输出 af = i 的 数 。 

3. 用 Java 语言 编写 程序 ， 扫 描 指定 文件 夹 下 面 所 有 以 .txt 或 .log 结尾 的 文件 ， 并 将 其 绝 
对 路 径 输 出 。 
4. 定义 有 数组 intm] a={L，2，3，3，4，3，2，…， 数 组 a 中 的 数 均 为 正 整数 ， 当 满足 
al[i+a[tj=a[x] 时 ， 其 中 ，i、 ft x 均 为 正 数 ， 且 小 于 等 于 n， 求 最 大 的 a[x]。 

5. 一 个 简单 的 论坛 系统 中 数据 库 扮演 着 非常 重要 的 角色 ， 假 设 数 据 库 需要 存储 如 下 的 一 
些 数据 : 用 户 名 、email、 主 页 、 电 话 、 联 系 地 址 、 发 帖 标题 、 发 帖 内 容 、 回 复 标题 以 及 回复 
内 容 。 每 天 论坛 的 访问 量 达 400 万 左右 ， 更 新 帖子 达 10 万 左右 。 请 给 出 数据 库 表 结构 设计 ， 
并 结合 范式 简要 说 明 设 计 思 路 。 


EEDEID， 某 知名 互联 网 公司 软件 工程 师 笔试 是 


一 、 单 项 选择 题 
1. 欲 构造 ArrayList 类 的 一 个 实例 ， 此 类 继承 了 List 接口 ， 下 列 方法 正确 的 是 〈 )。 


A. ArrayList myList=new Object(); B. ListmyList=new ArrayList(); 
C. ArrayList myList=new List(); D. ListmyList=new List(); 
2. paint0) 方 法 使 用 的 参数 类 型 是 (。 ”)。 
A. Graphics B. Graphics2D C. Strng D. Color 
3. 以 下 表达 式 中 ， 正 确 的 是 《 
A. Byte=128; B. Boolean=null; 
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C. Long l=0xfffl; D. Double=0.9239d; 
4. 有 如 下 代码 : 


public class Example 

{ 
String str=new String(“good”’); 
char[] ch={°a’,’b’,’c’}; 
public static void main(String args[]) 


{ 
Example ex=new Example(); 
Ex.change(ex.str,ex.ch); 
System.out.print(ex.strt“and”’); 
System.out.print(ex.ch); 
} 
public void change(String str,char ch []) 
{ 
str=”test ok”’; 
ch [0] = 
} 
} 
程序 的 运行 结果 为 (  )。 
A. good and abc B. goodand gbc 
C. test ok and abc D. test ok and gbc 


5. 有 如 下 代码 : 


public class X extends Thread implements Runable 
{ 
public void run() 
{ 
System.out.printin(“’this ls run()”); 
} 
public static void main(String args[]) 
{ 
Thread t= new Thread(new X()); 
t.start(); 


} 


程序 的 运行 结果 为 ” ”)。 
A. 第 一 行 会 产生 编译 错误 B. 第 六 行 会 产生 编译 错误 
C. 第 六 行 会 产生 运行 错误 D. 程序 会 运行 和 启 
6. 要 从 文件 ” file.dat "文件 中 读 出 第 10 个 字 节 到 变量 c 中 ， 下 列 方法 适合 的 是 ( )。 
A. FileInputStream in = new FileInputStream( file.dat); ee c= 1n.read(); 
B. FileInputStream in = new FileInputStream( “file.dat”); in.skip(10);int c = in.read(); 
C. FileInputStream in = new FileInputStream( “file.dat”); int ¢ = in.read(); 


un 
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D. RandomAccessFile in = new RandomAccessFile( file.dat ); in.skip(9); int c = in. 
readByte(); 
7. 容器 被 重新 设置 大 小 后 ,，(  ”) 布局 管理 器 的 容器 中 的 组 件 大 小 不 随 容器 大 小 的 变 
化 而 改变 。 
A. CardLayout B. FlowLayout 
C. BorderLayout D. GridLayout 
8. 有 如 下 代码 : 


public class Person 
{ 
static int arr[] = new int[10]; 
public static void main(String a[]) 
{ 
System.out.println(arr[1]); 


} 


} 
下 面 语句 正确 的 是 )。 


A. 编译 时 将 产生 错误 B. 编译 时 正确 ， 运 行 时 将 产生 错误 
C. 输出 零 D. 输出 空 

9. 可 以 对 对 象 加 互 斥 锁 的 关键 字 是 ( )。 
A. transient B. synchronized C. serialize D. static 


10. 下 列 关于 内 存 回 收 的 描述 中 ， 正 确 的 是 )。 
A. 程序 员 必 须 创 建 一 个 线程 来 释放 内 存 
B. 内 存 回收 程序 负责 释放 无 用 内 存 
C. 内 存 回 收 程序 允许 程序 员 直 接 释放 内 存 
D. 内 存 回收 程序 可 以 在 指定 的 时 间 释 放 内 存 对 象 
11. 下 列 代码 会 在 〈 ) 出 错 。 


1) public void modifyO{ 
2) int 1, j, k; 
3) i= 100; 
4) while (这 0){ 
5) i=j*2; 
6) System.out.println(“The value of j is ” +]); 
7) k=k+1; 
8) i--; 
9) } 
10) } 
A. line4 B. line 6 C. line7 D. line8 


二 、 多 项 选择 题 
1. 执行 下 列 代码 后 ， String[] s=new String[10];， 以 下 描述 正确 的 是 〈 ) 
A. s[10] 为 党 B. s[9] 为 null C.s[0] 为 未 定义 D. s.length 为 10 
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长 不 \ 后 
2. 下 面 的 表达 式 中 ， 正 确 的 是 ( ys 
A. String s =“ 你 好 ”; inti = 3; st=i; B.String s=“ 你 好 ” inti= 3; ifi=s){s+=); 
C. String s = “你 好 ”int i = 3; s=its; D. String s=“ 你 好 ”; inti= 3; s=i+; 


E. String s = “你 好 ”; inti= (s!=null))&&(s.length>0)?s.lengthO):0; 
3. 以 下 是 合理 的 标识 符 的 有 )。 


A. _sysl ll B. 2mail C. $change D. class 
4. 以 下 布局 管理 器 中 ， 使 用 的 是 组 件 的 最 佳 尺 寸 (preferred size) 的 是 ( )。 
A. FlowLayout B. BorderLayout C. GridLayout 


D. CardLayout E. ee ne 
5. 下 列 可 用 于 创建 一 个 可 运行 的 类 的 方法 有 (  ”)。 


A. public class X es Runable{public void run(O 全 }} 
B. public class X implements Thread {public void runO 全 }} 
C. public class X Implements Runable {public int run(){****** }} 
D. public class X implements Runable{protected void run(){**…*** }} 
E. public class X implements Thread {public void run(){***** }} 
6. 下 面 可 以 在 任何 时 候 被 任何 线程 调用 的 方法 有 (  )。 
A. notify () B. wait() C. notifyall() D. sleep() 
E. yield() F. synchronized(this) 
7. 构造 BufferedInputStream 的 合适 参数 是 ( js 
A. BufferedInputStream B. BufferedOutputStream 
C. FileInputStream D. FileOuterStream 
E. File 
8. 下 列 说 法 正确 的 是 ( ” ”)。 
A. Java.lang.Clonable 是 类 B. Java.lang.Runnable 是 接口 
C. Double 对 象 在 java.lang 包 中 D. Double a= 1.0 是 正确 的 Java 语句 
9. 以 下 表达 式 中 ， 正 确 的 有 和 
A. doublea=1.0; B. Doublea=new Double(1.0); 
C. bytea= 340; D. Bytea= 120; 


10. 定义 一 个 类 名 为 “MyClass.java” 的 类 ， 并 且 该 类 可 被 一 个 工程 中 的 所 有 类 访问 ， 那 


么 该 类 的 正确 声明 应 为 (  ”)。 


A. private class MyClass extends Object B. class MyClass extends Object 


C. public class MyClass D. public class MyClass extends Object 
下 列 方法 中 ， 与 方法 public void add(int a){} 为 合理 的 重 载 方法 的 是 (。”)。 

A. public int add(int a) B. public void add(long a) 

C. public void add(int a,int b) D. public void add(float a) 


12. 如 果 下 列 的 方法 能 够 正常 运行 ， 在 控制 台 上 将 显示 (  )。 


public void example() 


{ 


try 
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unsafe(); 
System.out.println(““Test 1”); 


} 


catch(SafeException e) 


{ 


System.out.println(Test 2”); 


} 
finally 


{ 


System.out.println(“Test 3”); 


} 


System.out.println(“Test 4 ); 


} 


A. Test1l B. Test2 
13. 下 列 可 以 终止 当前 线程 的 运行 的 是 


C. Test3 
eo 


D. Test4 


A. 当 抛 出 一 个 异常 时 
C.， 当 创建 一 个 新 线程 时 


B. 当 该 线程 调用 sleep0 方 法 时 
D.， 当 一 个 优先 级 高 的 线程 进入 就 绪 状 态 时 


1. 执行 下 列 代 码 后 的 结果 是 ( )。 int x, a=2 b=3, c=4; X=+ 二 ab 二 十 十 C 十 十 ; 

2. ( ”) 包 包 含 了 Collection 的 接口 和 类 的 API。 

3. main 方法 的 声明 格式 包括 se 

4. 下 列 程序 中 构造 了 一 个 SET 并 且 调 用 其 方法 add0， 和 输出 结果 是 《 )s 
public class A 


了 
1 


public int hashCode() 
{ 
return 1; 
} 
public Boolean equals (Object b){return true} 
public static void main(String args[]) 


{ 
Set set = new HashSet(); 
set.add(new A()); 
set.add(new A()); 
set.add(new A()); 
System.out.println(set.size()); 
} 
} 
5. 有 如 下 代码 : 
class Test 
{ 
class Dog 
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private String name; 
private int age; 
private int step; 
Dog(String s,int a) 
{ 
name = s; 
age=a; 
step= 0; 
} 
public void run(Dog fast) 


{ 
fast.step+ 十 ; 
} 
} 
public static void main (String args[]){ 
Testa= new Test(); 
Dog d= anew Dog("Tom",3); 
d.step = 25; 
d.run(d); 
System.out.println(d.step); 


} 


程序 的 运行 结果 是 ( ”)。 

四 、 编 程 题 

1. 编写 一 个 输出 “Hello World!” 的 程序 ， 用 两 种 方式 实现 (Application、Applet)。 

2. 用 输入 /输出 写 一 个 程序 ， 让 用 户 输 入 一 些 姓 名 和 电话 号 码 。 每 一 个 姓名 和 号 但 将 添 
加 在 文件 里 。 用 户 通 过 按 下 “Done” 按 钮 来 告诉 系统 整个 列表 已 输入 完毕 。 如 果 用 户 输入 完 
整个 列表 ， 程 序 将 创建 一 个 输出 文件 并 显示 或 打印 出 来 。 格 式 如 下 : 555-1212，Tom 
123-456-7890,，Peggy L. 234-567,Marc 234-5678，Ron 876-4321, Beth&Brian 33.1.42.45.70， 
Jean-Marc 。 


某 知名 网 络 安全 公司 校园 招聘 技术 类 笔试 题 


一 、 选 择 题 

1. 实验 高 中 的 小 明暗 恋 女 神 同 学 已 经 三 年 了 ， 高 考 结束 后 ， 小 明 决 定向 女神 同学 表白 。 
这 天 ， 小 明 来 到 女神 楼 下 等 待 女神 的 出 现 ， 时 间 一 分 一 秒 地 流逝 ， 两 个 多 小 时 过 去 了 ， 女 神 
还 没有 出 现 ， 小 明 看 了 下 表 ， 时 针 和 分 针 的 位 置 正 好 跟 开 始 等 的 时 候 互 换 ， 请 问 小 明 一 共 等 
了 女神 ( ””) 分 钟 。 

A. 165 B. 150 C. 172 D. 166 

2. 有 A、B、C 三 个 学 生 ， 他 们 中 一 个 出 生 在 西安 ， 一 个 出 生 在 武汉 ， 一 个 出 生 在 深圳 。 

一 个 学 化 学 专业 ， 一 个 学 英语 专业 ， 一 个 学 计算 机 。 其 中 〈1) 学 生 A 不 是 学 化 学 的 ， 学 生 B 
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是 学 计算 机 的 ; (2) 学 化 学 的 不 出 生 在 武汉 ; (3) 学 计算 机 的 出 生 在 西安 ，(4) 学 生 B 不 
出 生 在 深圳 。 根 据 上 述 条 件 可 知 ， 学 生 A 的 专业 是 ye 
A. 计算 机 B. 英语 C. 化 学 D. 3 种 专业 都 可 能 
3. 在 一 个 不 透明 的 箱子 里 ， 一 共有 红 、 黄 、 蓝 、 绿 、 白 五 种 颜色 的 小 球 ， 每 种 颜色 的 小 
球 大 小 相同 ， 质 量 相等 ， 数 量 充 足 。 每 个 人 从 箱子 里 抽出 两 个 小 球 ， 那 么 要 保证 有 两 个 人 抽 
到 的 小 球 颜色 相同 ， 至 少 需要 抽 球 的 人 数 为 〈 )。 
A. 11 个 B. 8 个 C. 16 个 D. 13 个 
4. 平面 内 一 共有 11 个 点 ， 由 它们 连 成 48 条 不 同 的 直线 ， 由 这 些 点 可 连 成 的 三 角形 个 数 
为 ( )。 


A. 162 B. 158 C. 160 D. 165 
5. 8, 8, 12, 24, 60, ( )， 括 号 内 填 的 内 容 是 ( )。 
A. 90 B. 180 C. 120 D. 240 
6. 有 如 下 代码 : 
int func(int x) 


{ 


int countx = 0; 


while (x) 

{ 
countx+t+; 
X= Xx&(x - 1); 

} 

return countx; 

} 
假设 x 的 值 为 65530， 那 么 func(x) 的 返回 值 是 ( )。 
A. 20 B. 16 C. 100 D. 14 


7. 用 某 种 排序 方法 对 关键 字 序 列 (25，84，21，47，15，27，68，35，20) 进行 排序 ， 
序列 的 变化 情况 如 下 所 示 : 

(1) 20，15，21，25，47，27，68，35，84 

(2) 15，20，21，25，35，27，47，68，84 

(3) 15, 20, 21, 25, 27, 35, 47, 68, 84 

则 采用 的 排序 方法 是 )s 


A. 选择 排序 B. 快速 排序 C. 和希 尔 排序 D. 归并 排序 
8. 设 某 棵 二 又 树 中 有 360 个 结 点 ， 则 该 二 又 树 的 最 小 高 度 是 (  )。 

A. 7 B. 9 C. 10 D. 8 
9. 下 列 排序 算法 中 ， 对 一 个 list 排序 的 最 快 方法 是 (  ”)。 


A. 快速 排序 B. 冒 泡 排序 C. 二 分 插入 排序 D. 线性 排序 
10. 应 用 程序 PING 发 出 的 是 ( ) 报 文 。 

A. ICMP 应 答 。 B. TCP 请 求 C. TCP 应 答 D. ICMP 请 求 
11. 有 如 下 规约 : 
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digit->0l1|.….|9 

digits->digit digit* 

optionalFraction ->.digits|8 
optionalExponent ->(E(+|-|s)digits)|s 


number -> digits optionalFraction optionlExponent 


以 下 无 符号 数 中 ， 不 符合 上 述 正则 规约 描述 要 求 的 是 (  ”)。 


Es 


A. 5280 B. 1 C. 2.0 D. 336E 
12. 语法 分 析 器 可 以 用 于 巴 

A. 识别 语法 错误 B. 识别 语法 和 语义 错误 

C. 识别 语义 错误 D. 识别 并 修正 语法 、 语 义 错误 
13. IPV6 地 址 包含 〈 ) 位 。 

A. 64 B. 16 C. 32 D. 128 


~ 


14. 在 Java 语言 的 Socket 通信 中 ， 通 常 采用 如 下 代码 来 读 取 网 络 上 接收 到 的 数据 : 


socket = new Socket(“hostName”,port); 
InputStream is=socket.getInputStream(); 


is.read(); 
其 中 ，read 方法 返回 -1 表示 ( 着 

A. 还 没有 收 到 对 端 数 据 B. 连接 发 生 错误 

C. 没有 可 用 的 学 节 D. 对 端 发 送 了 一 段 长 度 为 0 的 数据 
15. 以 下 不 是 内 核对 象 的 是 ( )。 

A. 进程 B. 线程 C. 互 斥 喜 D. 临界 区 
16. 同一 进程 下 的 多 个 线程 可 以 共享 的 资源 是 )。 

A. 栈 B. 数据 区 C. 寄存 器 D. 线程 ID 


17. 在 虚拟 存储 系统 中 ， 若 进程 在 内 存 中 占 3 块 (开始 时 为 空 )， 采 用 先进 先 出 页 面 淘汰 
算法 ， 当 执行 访问 页 号 序列 为 1、2、3、4、1、2、5、1、2、3、4、5、6 时 ， 将 产生 缺 页 中 
断 的 次 数 是 > 

A. 10 B. 9 C. 8 D. 7 

18. 下 述 情况 中 ， 会 提出 中 断 请 求 的 是 )。 

A. 在 键盘 输入 过 程 中 ， 每 按 一 次 键 ”B. 计算 结果 溢出 
C. 一 条 系统 汇编 指令 执行 完成 D. 两 数 相 加 结果 为 零 

19. 单 任 务 系统 中 两 个 程序 A 和 B， 其 中 

A 程序 ，CPU: 10s-> 设 备 1: 5s->CPU: 5s-> 设 备 2: 10s->CPU: 10s; 

B 程序 : 设备 1: 10s->CPU: 10s-> 设 备 2: 5s->CPU。5s-> 设 备 2: 10s; 

执行 顺序 为 A->B， 那 么 CPU 的 利用 率 是 ( )。 

A. 40% B. 50% C. 60% D. 70% 

20. 以 下 关于 守护 线程 的 说 法 中 ， 正 确 的 是 )。 

A. 所 有 非 守 护 线程 终止 ， 即 使 存在 守护 线程 ， 进 程 运行 终止 
B. 所 有 守护 线程 终止 ， 即 使 存在 非 守 护 线程 ， 进 程 运行 终止 
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2 


225 


23 . 


24. 


23; 


26. 


27. 


28 . 


C. 只 要 有 守护 线程 或 者 非 守 护 进程 其 中 之 一 存在 ， 进 程 就 不 会 终止 

D. 只 要 所 有 的 守护 线程 和 非 守护 线程 终止 运行 之 后 ， 进 程 才 会 终止 

以 下 关于 计算 机 的 描述 中 ， 不 正确 的 是 ( ” ”)。 

A. 进程 调度 中 “可 抢占 ”和 “ 非 抢 占 ” 两 种 方式 ， 后 者 引起 系统 的 开销 更 大 

B. 每 个 进程 都 有 自己 的 文件 描述 符 表 ， 所 有 进程 共享 同一 打开 文件 表 和 v-node 表 

C. 基本 的 存储 技术 包括 RAM、ROM、 磁 盘 以 及 SSD, 其 中 访问 速度 最 慢 的 是 磁盘 ， 
CPU 的 高 速 缓存 一 般 是 由 RAM 组 成 的 

D. 多 个 进程 竞争 资源 出 现 了 循环 等 待 可 能 造成 系统 死 锁 

下 列 关 于 Linux 操作 系统 的 描述 中 ， 正 确 的 是 (  )。 

A. 线性 访问 内 存 非法 时 ， 当 前 线程 会 进入 信号 处 理 函 数 

B. 用 mv 命令 移动 文件 时 ， 文 件 的 修改 时 间 会 发 生变 化 

C. ulimit -c 设置 的 是 函数 调用 栈 的 大 小 

D. malloc 函数 是 应 用 程序 向 操作 系统 申请 内 存 的 接口 

X86 体系 结构 在 保护 模式 中 有 三 种 地 址 ， 以 下 对 于 这 三 种 地 址 的 描述 ， 正 确 的 是 


A. 虚拟 地 址 先 经 过 分 段 机 制 映射 到 线性 地 址 ， 然 后 线性 地 址 通过 分 页 机 制 映射 到 
物理 地 址 
B. 线性 地 址 先 经 过 分 段 机 制 映射 到 虚拟 地 址 , 然后 虚拟 地 址 通 


| 


过 分 页 机 制 映射 到 物 


车 


C. 虚拟 地 址 先 经 过 分 页 机 制 映 射 到 线性 地 址 , 然后 线性 地 址 通过 分 段 机 制 映射 到 物 

里 地 址 

D. 线性 地 址 先 经 过 分 页 机 制 映射 到 虚拟 地 址 ， 然 后 线性 地 址 通过 分 段 机 制 映 射 到 
物理 地 址 。 

0.62 的 数据 类 型 是 ( ” ”)。 

A. float B. double C. Float D. Double 

利用 Thread.wait0 〇 同步 线程 ，( ) 设置 超时 时 间 。 

A. 可 以 B. 不 可 以 C. 不 确定 

下 列 ( ) 异常 是 检查 型 异常 ， 需 要 在 编写 程序 时 声明 。 

A. IndexOutOfBoundsException B. ClassCastException 

C. FileNotFoundException D. NullPointerException 

在 HTTP 协议 中 ， 用 于 发 送 大 量 数据 的 方法 是 (  ”)。 

A. get B. post C. put D. options 

有 如 下 代码 : 


~ 


int fun(int a) 
{ 
a=(1<<5)-1; 


return a; 


} 


fun(21) 的 结果 是 ( js 
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县 四 所 
A. 10 B. 8 CGC D. 31 
29. JDBC 的 主要 功能 有 (  )。 
A. 创建 与 数据 库 的 连接 B. 发 送 SQL 语句 到 数据 库 中 
C. 处 理 数 据 并 查询 结果 D. 以 上 都 是 
30. 以 下 语句 中 ， 创 建 了 一 个 数组 实例 的 是 (  ”)。 
A. int[|1ia= new int [15]; B. floatfa= new float [20]; 
C. char[] ca= “Some String”; D. ntila[]U = {4, 5, 6} {1, 2,3}; 


31. 假设 有 以 下 代码 String s=“hello”; String t=“hello”; char c[]={bh',e',1,1,0'} ,下 列 选项 中 ， 
返回 值 为 false 的 语句 是 ( )s 
A. s.equals(t) B. t.equals(c) 
C. s=—t D. t.equals(new String( hello”)) 
32. 在 Java 语言 中 ， 下 列 关 于 字符 集 编码 (Character set Encoding) 和 国际 化 Gil8n) 的 
问题 ， 正 确 的 是 »s 
A. 每 个 中 文字 符 占 用 2B， 每 个 英文 字符 占用 1B 
B. 假设 数据 库 中 的 字符 是 以 GBK 编码 的 ， 那 么 现实 数据 库 数据 的 网 页 也 必须 是 
GBK 编码 的 
C. Java 的 char 类 型 ， 以 UTF-16 Big Endian 的 方式 保存 一 个 字符 
D. 实现 国际 化 应 用 常用 的 手段 是 利用 ResourceBundle 类 
33. 将 一 颗 有 100 个 结 点 的 完全 二 义 树 从 根 这 一 层 开始 ， 进 行 广 度 侦 历 编 号 ， 那 么 编号 
最 小 的 叶 结 点 的 编号 是 )。 
A. 49 B. 50 C. S51 D; .52 
34. 当 分 析 XML 时 ， 需 要 校 验 结 点 是 否 闭合 ， 如 必须 有 与 之 对 应 ， 那 么 实现 比较 好 的 
数据 结构 是 泊 


A. 链表 B. 树 C. 队列 D. 栈 
35. 快速 排序 算法 在 序列 已 经 有 序 的 情况 下 的 复杂 度 为 (  )。 
A. Onlogn) B. (n*2) C. O(n) D. O(n’2log n) 


36. 无 向 图 G= (V, E), 其 中 V={a， b， Cy d， ey， f}， E={<a， b>， <a，e>，<a，C>， 
<b, e>, <e, 他 ,<f, d>, <e, d>}, 对 该 图 进行 深度 优先 排序 , 得 到 的 顶点 序列 正确 的 是 ( 5 


A. a, b, e, c, d, ff B. a, c, f, e, b, d 
C. d, ey， b， Cy， fs; d D. ay， ey， d， f, Cc， b 
二 、 问 答题 


1. 轮 询 任务 调度 和 可 抢占 式 调度 有 什么 区 别 ? 
2. 列 出 数据 库 中 常用 的 锁 及 其 应 用 场景 。 
3. 请 回答 以 下 关于 进程 、 线 程 以 及 程序 的 有 关 问 题 。 

(1) 进程 和 线程 的 区 别 是 什么 ? 

(2) 多 线程 程序 有 什么 优点 与 缺点 ? 

(3) 多 进程 程序 有 什么 优点 与 缺点 ? 与 多 线程 相 比 有 什么 区 别 ? 
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某 知名 互联 网 游戏 公司 校园 招聘 运 维 
开发 岗 笔试 题 


以 下 
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4. 下 列 关 于 地 址 转换 的 描述 中 ， 


、 单 项 选择 题 


1. 以 下 命令 中 ， 可 以 用 来 查看 当前 系统 局 动 时 间 的 是 4  ”)。 


A. vw B. top 


2. Linux 下 的 进程 有 以 下 ) 


A. 精确 态 、 模 糊 态 和 随机 态 
C. 准备 态 、 执 行 态 和 退出 态 


3. 如 果 系 统 的 umask 设置 为 244， 


C. ps 
三 种 状态 。 


B. 运行 态 、 a 
D. 手动 态 、 自 动态 和 自 


那么 创建 一 个 新 文件 


D. uptime 


济 济 


FF 后， 它 的 权限 是 ( ¢ )。 


A. --W-r--f-- B. -r-xr--r-- C. -rf---W--W-- D. -r-X-WX-WX 


错误 的 是 (  )。 


A. 地 址 转换 解决 了 因特网 地 址 短缺 所 面临 的 问题 
B. 地 址 转换 实现 了 对 用 户 透明 的 网 络 外 部 地 址 的 分 配 


C. 使 用 地 址 转换 后 ， 对 IP 包 加 长 、 


D. 地 址 转换 内 部 主机 提供 一 定 的 “隐私 ” 


5. 下 列 给 定 地 址 中 ， 与 192.168.1. 


A. 重 定向 B. Echo 响应 
7. 以 下 关于 传输 层 协议 UDP 的 描述 中 ， 正 确 的 有 ( 
A. 比较 合适 传输 小 的 数据 文件 


C. 提供 了 高 的 传输 效率 


110/27 属于 同一 个 子 


A. 封装 B. 流量 探 


9. 在 bash 中 ， 以 下 说 法 正确 的 是 


A. 表示 参数 的 数量 
C. $@ 表 示 当 前 进程 的 pid 


法 正确 的 是 (  )。 
A. bash demo.sh &>demo.log 


C. bash demo.sh >demo.log 2>&1 


( )。 


快速 转发 不 会 造成 什么 影响 


网 的 主机 地 址 是 )。 


)。 


B. 提高 了 传输 的 可 靠 性 
D. 使 用 窗口 机 制 来 实现 流量 控 秆 
8. 下 列 功 能 中 ， 能 使 TCP 准确 可 靠 地 从 源 设备 到 目地 设备 传输 数据 的 是 

制 C. 无 连接 服务 ”D. 编号 和 定 


B. $$ 表示 当前 进程 的 名 字 


D. $? 表 示 前 一 个 命令 的 返回 值 
10. 在 bash 中 , 需要 将 脚本 demo.sh 的 标准 输出 和 标准 


二 


A. 192.168.1.94 ©B. 192.168.1.96 C. 192.168.1.124 D. 192.168.1.126 
6. PING 命令 使 用 ICMP 的 ( ) 代码 类 型 。 


C. 源 抑 制 D. 目标 不 可 达 


We 
o 


错误 输出 重 定向 至 文件 demo.log， 


B. bash demo.sh>&demo.log 


11. 在 bash 中 ， 下 列 语句 是 赋值 语句 的 是 (  ”)。 
A. a="test" B. $a="test" C. a="test" D. $a="test" 
demo.log) 中 包含 ERP 的 行 到 标准 输出 的 是 
B. sed VERP/p' demo.log 
D. sed -n /ERP/p' demo.log 


.以 下 命令 中 ， 可 以 打印 文件 ( 
A. sed /ERR/a\ demo.log 
C. sed VERP/d demo.log 


D. bash demo.sh 2>demo.log 1>demo.log 


js 


4 
E 
d 


13. 使 用 dkpg 命令 安装 的 软件 为 ( ” )。 


A. .pm B. .tar.gz C. .tar.bz2 D. .deb 
14. 链表 要 求 元 素 的 存储 地 址 (。 ”)。 
A. 必须 连续 B. 部 分 连续 C. 必须 不 连续 ” D. 连续 与 否 均 可 
15. 如 果 采 用 哈 希 表 组 织 100 万 条 记录 ， 以 支持 字段 A 快速 查找 ， 那 么 以 下 描述 中 ， 正 
确 的 是 (  ”)。 


A. 理论 上 可 以 在 常数 时 间 内 找到 特定 记录 
B. 所 有 记录 必须 存在 内 存 中 
C 
D 


， 拉链 式 哈 希 法 的 最 坏 查 找 时 间 复 杂 度 是 O(n) 
哈 希 函数 的 选择 与 字段 A 无 关 
16. 当 执 行 Mysql 查询 时 ， 只 有 满足 连接 条 件 的 记录 才 包 含 在 查询 结果 中 ， 这 种 连接 是 


A. 左 连 接 B. 右 连 接 C. 内 连接 D. 全 连接 
17. 对 于 一 棵 排序 二 又 树 ， 可 以 得 到 有 序 序列 的 遍历 方式 是 ) 遍历 。 

A. 前 序 B. 中 序 C. 后 序 D. 都 可 以 
18. JavaScript 定义 var a="40"，var b=7， 则 执行 a%b 会 得 到 ( )s 

A. 5 B. "5" C. undefined D. null 


19. 下 面 有 关 CSS Sprites 的 描述 中 ， 错 误 的 是 〈 半 
A. 允许 将 一 个 页 面 涉及 的 所 有 和 零星 图 片 都 包含 到 一 张大 图 中 
B. 利用 CSS 的 “background-image”“background- repeat” 和 “background-position?” 
的 组 合 进 行 背景 定位 
C. CSS Sprites 昌 然 增加 了 图 片 的 字 节 ， 但 是 很 好 地 减少 了 网 页 的 HTTP 请 求 ， 从 
而 大 大 地 提高 了 页 面 的 性 能 
D. CSS Sprites 整理 起 来 更 为 方便 ， 同 一 个 按钮 不 同 状态 的 图 片 也 不 需要 一 个 个 切 
割 出 来 并 个 别 命名 
20. 下 列 关 于 视图 与 基本 表 的 对 比 描述 中 ， 正 确 的 是 (  )。 
A. 视图 的 定义 功能 强 于 基本 表 
B. 视图 的 操作 功能 强 于 基本 表 
C. 视图 的 数据 控制 功能 弱 于 基本 表 
D. 上 面 提 到 的 三 种 功能 二 者 均 相 当 
21. 一 个 关系 模式 为 Y (X1，X2，X3，X4)， 假 定 该 关系 存在 着 如 下 函数 依赖 : (X1， 
X2) 一 X3，X2-X4， 则 该 关系 属于 (  ”)。 
A. 第 一 范式 B. 第 二 范式 C. 第 三 范式 D. 第 四 范式 
22. 最 佳 二 又 搜 索 树 是 )。 
A. 关键 码 个 数 最 少 的 二 又 搜 索 树 
.搜索 时 平均 比较 次 数 最 少 的 二 又 搜索 树 
C. 所 有 结 点 的 左 子 树 都 为 空 的 二 叉 搜索 树 
D. 所 有 结 点 的 右 子 树 都 为 空 的 二 又 搜索 树 


> 


lee) 
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二 、 多 项 选择 题 
1. 在 Linux 操作 系统 中 ， 以 下 关于 硬 链 接 的 描述 中 ， 正 确 的 是 by 
A. 跨 文件 系统 
B. 不 可 以 跨 文 件 系统 
C. 为 链接 文件 创建 新 的 i 结 点 
D. 链接 文件 的 i 结 点 与 被 链接 文件 的 i 结 点 相同 
2. 下 面 不 是 进程 和 程序 的 区 别 的 是 )。 
A. 程序 是 一 组 有 序 的 静态 指令 ， 进 程 是 一 次 程序 的 执行 过 程 
B. 程序 只 能 在 前 台 运 行 ， 而 进程 可 以 在 前 台 或 后 台 运 行 
C. 程序 可 以 长 期 保存 ， 进 程 是 暂时 的 
D. 程序 没有 状态 ， 而 进程 是 有 状态 的 
3. 正则 表达 式 A*B 可 以 匹配 的 字符 串 是 〈 )。 


A. A B. ACB C. AB D. AAB 
4. 以 下 是 行内 元 素 的 有 (  ”)。 
A. span B. input C. ul D. p 


5. 以 下 关于 Cookie 的 描述 中 ， 不 正确 的 是 js 
A. 根 域名 可 以 访问 子 域 的 Cookie 
B. 浏览 器 禁用 Cookie 时 可 以 用 URL 重 写 与 服务 端 保 持 状 态 
C. Cookie 没有 大 小 限 币 
D. Cookie 中 保存 的 是 字符 串 

6. 以 下 有 关 聚 集 索 引 的 描述 中 ， 正 确 的 是 a 


一 


A. 有 存储 实际 数据 B. 没有 存储 实际 数据 
C. 物理 上 连续 D. 逻辑 上 连续 
E. 可 以 用 B 树 实现 F， 可 以 用 二 又 排序 树 实现 


7. 以 下 关于 Web 站 点 的 描述 中 ， 正 确 的 有 污 
A. 静态 网 站 是 指 这 个 网 站 的 内 容 无 法 更 改 
可 以 使 用 同一 个 网 址 访问 不 同 的 Web 服务 器 
使 用 127.0.0.1 不 能 访问 本 地 站 点 
. DDos、 绥 存 溢出 、XSS 和 AJAX 都 属于 Web 站 点 的 入 侵 方式 
、 填 空 题 
一 个 具有 3 个 结 点 的 二 叉 树 可 以 有 ( ) 种 形态 。 
把 4000 个 结 点 组 成 一 棵 二 又 树 ， 最 小 高 度 是 〈 )。 
表达 式 ((A+B)*C-(D-EX(F+G)) 的 前 级 表达 式 是 )。 
四 、 问 答题 
1. 某 游 戏 的 客户 端 每 阳 Smin 会 向 服务 端 报告 一 次 玩家 的 账户 积分 ， 如 果 两 次 报告 的 时 
间 间 隔 不 大 于 Smin， 则 认为 该 玩家 在 这 5min 内 在 线 ， 假 设 报告 数据 的 格式 如 下 ; 


Dom 


ll 


IP Datetime Score 


223.152.112.238 2014-08-22 12:01:35 54232 
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现 有 一 天 的 数据 ， 按 时 间 按 序 保存 ， 粗 略 估计 玩家 数 在 百 万 左右 ， 请 使 用 尽量 少 的 硬件 
资源 完成 以 下 请 求 ， 用 代码 、 伪 代码 或 其 他 你 觉得 可 以 表述 清楚 的 方式 描述 你 的 方法 。 统 计 
在 线 时 长 最 长 的 十 个 玩家 ; 如 果 玩 家 两 次 提交 的 积分 相同 ， 认 为 玩家 在 Smin 的 在 线 时 间 内 不 
活跃 ， 请 统计 一 天 内 一 直 处 于 不 活跃 状态 的 玩家 的 百分比 。( 注 : 积分 可 增 可 减 ) 

2. 一 个 人 在 社区 中 会 有 各 种 各 样 的 身份 ， 和 不 同 的 人 相处 会 有 不 同 的 关系 。 请 自行 设计 
数据 库 〈 表 结构 ， 个 数 不 限 )， 保 存 一 个 人 的 名 字 、 关 系 〈 包 括 父 亲 ， 朋 友 们 )， 并 尽 可 能 少 
的 时 间 空 间 开销 组 织 好 每 个 人 和 其 他 人 的 关系 ， 组 织 好 后 尝试 取出 一 个 人 的 关系 结构 。 请 
详细 写 出 其 中 涉及 的 SQL 语句 、 数 据 结 构 和 数据 组 织 ,代码 可 以 用 伪 代 码 或 你 熟悉 的 任何 
代码 。 


91 


真题 评 解 局 


真题 详解 篇 主要 针对 18 套 真 题 进行 深度 剖析 ， 在 写法 上 ， 应 丁 解 牛 ， 针 对 每 
一 道 题目 都 有 非常 详细 的 解答 。 授 之 以 鱼 的 同时 还 授 之 以 渔 ， 不 仅 告 诉 答案 ， 还 
告诉 读者 以 后 再 遇 到 同类 型 题目 时 该 如 何 解答 。 读 者 学 完 基 础 知识 后 ， 可 以 抽出 
一 两 个 小 时 的 时 间 来 完成 本 书 中 的 习题 ， 找 出 自己 的 知识 育 区 ， 查 漏 补 缺 ， 为 自 
己 加 油 、 补 课 。 


TU 昌 有 某 知 名 互联 网 下 载 服 务 提 供 商 软件 
工程 师 笔 试题 


1. 答案 : B。 
分 析 : 本 题 考 察 的 是 Java 语言 中 访问 修饰 符 作 用 范围 的 知识 。 
在 Java 语言 中 ， 类 的 权限 访问 修饰 符 有 以 下 几 种 : private、default (package)、protected 
和 public。 下 面具 体 对 这 几 个 权限 访问 修饰 符 进行 介绍 。 
(1) 私有 权限 (private) 
private 可 以 修饰 数据 成 员 、 构 造 方法 及 方法 成 员 ， 不 可 以 修饰 类 此 处 指 外 部 类 ， 不 考 
虑 内 部 类 )。 被 private 修饰 的 成 员 ， 只 能 在 定义 它们 的 类 中 使 用 ， 在 其 他 类 中 不 能 调用 。 
(2) 默认 权限 (default) 
类 、 数 据 成 员 、 构 造 方法 和 方法 成 员 等 都 能 够 使 用 默认 权限 ， 即 不 被 private、protected 
和 public 修饰 。 默 认 权 限 即 同 包 权限 ， 同 包 权 限 的 元 素 只 能 在 定义 它们 的 类 中 以 及 同 包 的 类 
中 被 调用 。 
(3) 受 保护 权限 (protected) 
protected 可 以 修饰 数据 成 员 、 构 造 方法 和 方法 成 员 ， 不 可 以 修饰 类 〈 此 处 指 外 部 类 ， 不 
考虑 内 部 类 )。 被 protected 修饰 的 成 员 ， 能 在 定义 它们 的 类 中 以 及 同 包 的 类 中 被 调用 。 如 果 有 
不 同 包 的 类 想 调 用 它们 ， 那 么 这 个 类 必须 是 它 的 子 类 。 
(4) 公共 权限 (public) 
public 可 以 修饰 类 、 数 据 成 员 、 构 造 方法 及 方法 成 员 。 被 public 修饰 的 成 员 ， 可 以 在 任 
何 一 个 类 中 被 调用 ， 不 管 同 包 或 不 同 包 ， 是 权限 最 大 的 一 个 修饰 符 。 
以 上 几 种 修饰 符 的 使 用 范围 见 表 2 ( 表 中 表示 可 访问 ，X 表 示 不 可 访问 )。 
表 2 修饰 符 的 使 用 范围 


范 围 private default protected public 
同一 类 y + + 
同一 包 中 的 类 x y y y 
同一 包 中 的 类 、 不 同 包 中 的 子 类 x x y Y 
所 有 x x x y 


通过 表 2 可 知 ， 访 问 修 饰 符 的 作用 范围 由 大 到 小 依次 是 public、protected、default 和 
private。 所 以 ， 选 项 B 正确 。 

所 以 ， 本 题 的 答案 为 了 B。 

2. 答案 : B。 

分 析 : 本 题 考察 的 是 Java 语言 中 基本 数据 结构 的 知识 。 

对 于 选项 A，List 中 保存 了 相同 类 型 的 多 个 元 素 ， 元 素 是 按照 存 入 的 顺序 存储 的 ， 元 素 
可 以 重复 。 所 以 ， 选 项 A 错误 。 

对 于 选项 B，Map 是 以 键 - 值 对 的 方式 来 存储 对 象 的 ， 并 且 键 不 允许 重复 。 所 以 ， 选 项 B 
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对 于 选项 C，java.util.Collection 是 一 个 集合 接口 ， 它 提供 了 对 集合 对 和 象 进行 基本 操作 的 
通用 接口 方法 。 而 Set 与 List 是 它 的 两 个 具体 的 接口 ， 由 于 Set 与 List 都 不 是 以 键 - 值 对 的 方 
式 来 存储 对 象 的 ， 因 此 ，Collection 接口 也 不 是 。 所 以 ， 选 项 C 错误 。 

对 于 选项 D，Set 中 也 保存 了 相同 类 型 的 多 个 元 素 ， 元 素 是 不 能 重复 的 。 所 以 ， 选 项 了 D 错误 。 
各 接口 的 区 别 见 表 3。 


表 3 各 接口 的 区 别 


类 型 是 否 有 序 是 否 允 许 重 复 是 否 线程 同步 
Collection 否 是 一 
ArrayList 得 
List Vector 在 是 是 
LinkedList 否 
HashSet 否 否 
Set 否 - 
TreeSet 是 否 
HashMap 否 否 
日 <key, value>， a 
Map TreeMap 是 key 不 允许 重复 奋 
Hashtable 省 是 


所 以 ， 本 题 的 答案 为 了 B。 

3. 答案 : D。 

分 析 : 本 题 考察 的 是 Object 类 的 知识 。 

Object 类 是 类 层次 结构 的 根 ， 在 Java 语言 中 ， 所 有 的 类 从 根本 上 而 言 都 继承 自 这 个 类 。 
而 且 ，Object 类 是 Java 语言 中 唯一 没有 父 类 的 类 ， 而 其 他 所 有 的 类 ， 包 括 标 准 容器 类 ， 例 如 
数组 ， 都 继承 了 Object 类 。 
具体 而 言 ，Object 类 的 方法 见 表 4。 

表 4 Object 类 的 方法 


方 法 名 返回 类 型 方法 描述 
clone0 Object 创建 并 返回 此 对 象 的 一 个 副本 
equals(Object obj) boolean 判断 obj 对 象 是 否 与 此 对 象 相等 
finalize() void 当 垃 圾 回收 器 确定 不 存在 对 该 对 象 的 更 多 引用 时 ， 由 对 象 的 垃圾 回收 器 调用 此 方法 
getClass() Class<?> 返回 此 Object 的 运行 时 类 
hashCode() int 返回 该 对 象 的 哈 希 码 值 
notify0 void 唤醒 在 此 对 象 监 视 器 上 等 待 的 单个 线程 
notifyAll0 void 唤醒 在 此 对 象 监 视 器 上 等 待 的 所 有 线程 
toString() String 返回 该 对 象 的 字符 串 表 示 
wait() void 在 其 他 线程 调用 此 对 象 的 notify0 方 法 或 notifyAll0 方 法 前 ， 使 当前 线程 等 待 
, ; i 在 其 他 线程 调用 此 对 象 的 notify0 方 法 或 notifyAll0 方 法 ， 或 者 超过 指定 的 时 间 量 前 ， 
wait(long timeout) void 使 当前 线程 等 竺 
wait(long timeout, i 在 其 他 线程 调用 此 对 象 的 noti fy() 方 法 或 notifyAUO 方 法 ， 或 者 其 他 某 个 线程 中 断 当 前 
intnanos) 线程 ， 或 者 已 超过 某 个 实际 时 间 量 前 ， 使 当前 线程 等 待 
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此 可 见 ，Object 类 没有 hasNext0 方 法 。 所 以 ， 选 项 DD 正确 。 
所 以 ， 本 题 的 答案 为 DD。 

4. 答案 : B。 

分 析 : 本 题 考察 的 是 Java 语言 中 传 参 方式 以 及 不 可 变 类 的 知识 。 

不 可 变 类 (Immutable class) 是 指 当 创建 了 这 个 类 的 实例 后 ， 就 不 允许 修改 它 的 值 了 ， 也 
就 是 说 ， 一 个 对 象 一 旦 被 创建 出 来 ， 在 其 整个 生命 周期 中 ， 它 的 成 员 变 量 就 不 能 被 修改 了 。 
它 有 点 类 似 于 常量 (const), 即 只 允许 其 他 程序 进行 读 操 作 , 而 不 允许 其 他 程序 进行 修改 操作 。 
在 Java 类 库 中 ,所 有 基本 类 型 的 包装 类 都 是 不 可 变 类 , 例如 Integer、Float 等 。 此 外 ， 
String 也 是 不 可 变 类 。 可 能 有 人 会 有 疑问 ， 既 然 String 是 不 可 变 类 , 为 什么 还 可 以 写 出 如 下 代 
码 来 修改 String 类 型 的 值 呢 ? 
public class Test 


{ 


public static void main(String[] args) 


String s="Hello"; 
s+=" world"; 
System.out.println(s); 


} 


旦 序 的 运行 结果 为 
Hello world 


表面 上 看 ，s+="world" 的 作用 好 像 是 修改 String 类 型 对 象 s 的 值 ， 其 实 不 是 ，String s="Hello" 
语句 声明 了 一 个 可 以 指向 String 类 型 对 和 象 的 引用 ， 这 个 引用 的 名 字 为 s， 它 指向 了 一 个 字符 串 常量 
"Hello"。s+="world" 并 没有 改变 s 所 指向 的 字符 串 的 值 (由 于 "Hello" 是 String 类 型 的 对 象 , 而 String 
又 是 不 可 变量 )， 在 这 行 代码 运行 后 ，s 指向 了 另外 一 个 String 类 型 的 对 象 ， 该 对 象 的 内 容 为 
"Hello world"。 原 来 的 那个 字符 串 常 量 "Hello" 还 存在 于 内 存 中 ， 并 没有 被 改变 。 
在 Java 语言 中 ， 除 了 8 种 原始 的 数据 类 型 (分别 为 byte、short、int、long、float、double、 
char 和 boolean) 外 ， 其 他 的 类 型 都 是 对 象 ， 在 方法 调用 的 时 候 ， 传 递 的 都 是 引用 。 引 用 从 本 
质 上 来 讲 也 是 按 值 传递 ， 只 不 过 传递 的 这 个 值 是 对 象 的 引用 而 已 ， 因 此 ， 在 方法 调用 的 时 候 ， 
对 形 参 引用 所 指 对 象 属性 值 的 修改 对 实 参 可 见 。 但 是 对 引用 值 本 身 的 修改 对 实 参 是 不 可 见 的 。 

回 到 本 题 中 来 ， 在 调用 change 方法 的 时 候 ，change 方法 的 形 参 str 实际 上 是 实 参 str (main 
方法 中 的 str) 的 一 个 副本 ， 由 于 String 是 不 可 变量 ， 因 此 ， 无 法 通过 str 来 修改 这 个 字符 串 的 
内 容 , 执行 语句 str="test ok" 的 结果 是 使 形 参 的 str 指向 了 另外 一 个 常量 字符 串 (可 以 理解 为 修 
改 了 形 参 的 值 ， 而 不 是 修改 了 形 参 所 指向 对 象 的 值 )， 但 是 这 个 修改 对 实 参 是 不 可 见 的 ， 调 用 
change 方法 结束 后 对 象 的 main 方法 中 str 的 值 还 是 "good", 而 change 方法 的 形 参 ch 也 是 实 参 
ch (main 方法 中 的 ch 值 ) 的 一 个 副本 ， 但 是 在 这 个 方法 中 通过 形 参 ch 修改 了 实 参 ch 所 指向 
对 象 的 值 ， 即 数组 元 素 的 值 ， 形 参 ch 与 实 参 ch 指向 的 是 同一 个 对 象 ， 因 此 ， 通 过 形 参 对 这 
个 对 象 值 的 修改 对 实 参 是 可 见 的 ， 所 以 ， 当 调用 ex.change 方法 后 ，main 方法 中 ch 指向 的 数 
组 的 值 变 为 {“g”,，“b”，,“c”}， 因 为 该 方法 只 是 改变 了 ch[0] 的 值 而 已 ， 所 以 ， 程 序 最 终 输 
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出 为 字符 串 "good and gbc"。 所 以 ， 选 项 B 正确 。 


所 以 ， 本 题 的 答案 为 B。 


1 . 


分 析 : 本 题 考察 的 是 Math 类 中 round 方法 的 使 用 。 


答案 : 13， 一 12。 


Math 类 主要 提供 了 下 面 5 个 与 取 整 相关 的 方法 : 
1) static double ceil(double a): 返回 大 于 等 于 a 的 最 小 整数 。 
2) static double floor(double a): 返回 小 于 等 于 a 的 最 大 整数 。 


3) static double rint(double a): 四 侈 五 入 方法 ， 返 


类 型 


= 


4) static long round(double a): 四 舍 五 入 方法 ， 返 回 与 a 的 值 最 相近 的 长 整 型 数 。 
5) static int round(float a):; 四 舍 五 入 方法 ， 返 回 与 a 的 值 最 相近 的 整 型 数 。 


对 于 本 题 而 言 ，round 是 一 个 四 舍 五 入 的 方法 ，12.5 的 小 数 部 分 为 0.5， 当 对 其 执行 


回 与 a 的 值 最 相近 的 整数 ， 为 double 


Math.round0) 操 作 时 ， 结 果 需 要 四 舍 五 入 ， 所 以 ， 结 果 为 13; -12.5 的 小 数 部 分 也 为 0.5， 当 对 


其 执行 
2 


Math.round() 操 作 时 ， 结 果 也 需要 四 舍 五 入 ， 由 于 -12>-13， 因 此 ， 结 果 为 -12。 
答案 : false。 


分 析 : 本题 考察 的 是 字符 串 知识 。 
在 Java 语言 中 ， 除 了 8 种 基本 的 数据 类 型 外 ， 其 他 的 类 型 都 为 引用 类 型 ， 因 此 ， 
strl 一 str2 的 功能 是 比较 strl 与 str2 这 两 个 字符 串 的 地 址 是 否 相 同 ， 显 然 ，strl 存储 在 常量 区 ， 


而 str2 
地 址 。 
3 . 


语句 


因此 ， 程 序 的 运行 结果 为 false。 
答案 : 浮 点 型 float、double，char，byte、short、int、long。 


分 析 : 本 题 考 察 的 是 Java 数据 类 型 的 知识 。 
Java 语言 中 只 有 8 种 基本 数据 类 型 ， 分 别 为 byte、short、int、long、float、double 
和 boolean。 在 方法 调用 传 参 时 ， 这 8 种 基本 数据 类 型 都 是 按 值 传递 的 ， 除 此 之 外 ， 所 有 的 数 


据 类 型 


都 是 按 引 用 传递 的 。 


以 上 分 析 可 知 , 本 题 的 答案 为 : 浮 点 型 float、 double, 字符 类 型 char, 布尔 类 型 bo 


数值 类 型 byte、short、int、long。 


4. 


答案 : String，StringBuffer。 


分 析 : 本 题 考察 的 是 对 Java 字符 串 的 理解 。 
Java 语言 中 ，String 是 不 可 变 类 ， 也 就 是 说 ，String 对 象 一 旦 被 创建 ， 其 值 将 不 能 被 改 
| 


在 
变 ， 而 


可 变 类 ， 


StringBuffer 是 可 变 类 ， 当 对 象 被 创建 后 ， 仍 然 可 以 对 其 值 进行 修改 。 
因此 ， 适 合 在 需要 被 共享 的 场合 中 使 用 ， 而 当 一 个 字符 串 经 常 需要 被 修改 时 ， 


中 的 “world” 是 在 堆 空 间 上 申请 的 另外 一 块 存储 空间 ， 因 此 ， 二 者 必然 有 不 同 的 存储 


、Cchar 


olean， 


对 ie 是 有 


最 好 


使 用 StringBuffer 来 实现 。 如 果 使 用 String 来 保存 一 个 经 常 被 修改 的 字符 串 ， 在 字符 串 被 修改 


的 时 候 会 比 StringBuffer 多 了 很 多 附加 的 操作 ， 同 时 会 生成 很 多 无 用 的 对 象 ， 由 于 这 些 无 用 的 
对 象 会 被 垃圾 回收 器 回收 ， 所 以 ， 会 影响 程序 的 性 能 。 在 规模 小 的 项 目 中 这 种 影响 很 小 ， 但 
是 在 一 个 规模 大 的 项 目 中 ， 这 会 给 程序 的 运行 效率 带 来 很 大 的 负面 影响 。 


1 . 
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答案 : 接口 (interface) 和 抽象 类 (abstract class) 是 支持 抽象 类 定义 的 两 种 机 


前 〈 注 


真题 详解 篇 


意 ， 该 句 中 前 后 两 个 抽象 类 的 意义 不 一 样 ， 前 者 表示 的 是 一 个 实体 ， 后 者 表示 的 是 一 个 概念 )。 
两 者 具有 很 大 的 相似 性 ， 甚 至 有 时 候 是 可 以 互 换 的 。 但 同时 ， 两 者 也 存在 很 大 的 区 别 。 
具体 而 言 ， 接 口 是 公 开 的 ， 里 面 不 能 有 私有 的 方法 或 变量 ， 是 用 于 让 别人 使 用 的 ， 而 抽 
象 类 是 可 以 有 私有 方法 或 私有 变量 的 ， 如 果 一 个 类 中 包含 抽象 方法 ， 那 么 这 个 类 就 是 抽象 类 。 
在 Java 语言 中 ， 可 以 通过 把 类 或 者 类 中 的 某 些 方法 声明 为 abstract (abstract 只 能 用 来 修饰 类 
或 者 方法 ， 不 能 用 来 修饰 属性 ) 来 表示 一 个 类 是 抽象 类 。 接 口 就 是 指 一 个 方法 的 集合 ， 接 
中 的 所 有 方法 都 没有 方法 体 ， 在 Java 语言 中 ， 接 口 是 通 过 关键 字 interface 来 实现 的 。 

包含 一 个 或 多 个 抽象 方法 的 类 就 必须 被 声明 为 抽象 类 ， 抽 象 类 可 以 声明 方法 的 存在 而 不 
去 实现 它 ， 被 声明 为 抽象 的 方法 不 能 包含 方法 体 。 在 抽象 类 的 子 类 中 ， 实 现 方法 必须 含有 相 
同 的 或 者 更 低 的 访问 级 别 (public->protected->private)。 抽象 类 在 使 用 的 过 程 中 不 能 被 实例 化 ， 
但 是 可 以 创建 一 个 对 象 使 其 指向 具体 子 类 的 一 个 实例 。 抽 象 类 的 子 类 为 父 类 中 所 有 的 抽象 方 
法 提供 具体 的 实现 ， 否 则 ， 它 们 也 是 抽象 类 。 接 口 可 以 被 看 作 是 抽象 类 的 变 体 ， 接 口中 所 有 
的 方法 都 是 抽象 的 ， 可 以 通过 接口 来 间接 地 实现 多 重 继 承 。 接 口中 的 成 员 变 量 都 是 static final 
类 型 ， 由 于 抽象 类 可 以 包含 部 分 方法 的 实现 ， 所 以 ， 在 一 些 场合 下 抽象 类 比 接口 存在 更 多 的 
优势 。 

接口 与 抽象 类 的 相同 点 如 下 : 

1) 都 不 能 被 实例 化 。 

2) 接口 的 实现 类 或 抽象 类 的 子 类 都 只 有 实现 了 接口 或 抽象 类 中 的 方法 后 才能 被 实 
例 化 。 

接口 与 抽象 类 的 不 同 点 如 下 : 

1) 接口 具有 定义 ， 不 能 有 方法 的 实现 ， 而 抽象 类 可 以 有 定义 与 实现 ， 即 其 方法 可 以 在 抽 
象 类 中 被 实现 。 

2) 实现 接口 的 关键 字 为 implements， 继 承 抽象 类 的 关键 字 为 extends。 一 个 类 可 以 实 
现 多 个 接口 ， 但 一 个 类 只 能 继承 一 个 抽象 类 ， 因 此 ， 使 用 接口 可 以 间接 地 达到 多 重 继承 的 
目的 。 

3) 接口 强调 特定 功能 的 实现 ， 其 设计 理念 是 “has-a” 关 系 ， 而 抽象 类 强调 所 属 关 系 ， 其 
设计 理念 为 “is-a” 关 系 。 

4) 接口 中 定义 的 成 员 变量 默认 为 public static final， 只 能 够 有 静态 的 不 能 被 修改 的 数据 成 
员 ， 而 且 ， 必 须 给 其 赋 初 值 ， 其 所 有 的 成 员 方法 都 是 public、abstract 的 ， 而 且 只 能 被 这 两 个 
关键 字 修饰 。 而 抽象 类 可 以 有 自己 的 数据 成 员 变 量 ， 也 可 以 有 非 抽 象 的 成 员 方法 ， 而 且 ， 抽 
象 类 中 的 成 员 变 量 默认 为 default， 当 然 也 可 以 被 定义 为 private、protected 和 public， 这 些 成 员 
变量 可 以 在 子 类 中 被 重新 定义 ， 也 可 以 被 重新 赋值 ， 抽 象 类 中 的 抽象 方法 (其 前 有 abstract 
修饰 ) 不 能 用 private、static、synchronized 和 native 等 访问 修饰 符 修饰 ， 同 时 方法 必须 以 分 号 
结尾 ， 并 且 不 带 花 括号 {}。 所 以 ， 当 功能 需要 累积 时 ， 使 用 抽象 类 ; 不 需要 累积 时 ， 使 用 
接口 。 

5) 接口 被 运用 于 实现 比较 常用 的 功能 ， 便 于 日 后 维护 或 者 添加 删除 方法 ， 而 抽象 类 更 倾 
向 于 充当 公共 类 的 角色 ， 不 适用 于 日 后 重新 对 里 面 的 代码 进行 修改 。 

2. 答案 : Java 虚拟 机 (Java Virtual Machine，JVM， 是 运行 所 有 Java 程序 的 抽象 计算 机 ， 
是 Java 语言 的 运行 环境 ) 允许 应 用 程序 并 发 地 运行 多 个 线程 。 在 Java 语言 中 ， 多 线程 的 实现 
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般 有 以 下 三 种 方法 : 
1) 实现 Runnable 接口 ， 并 实现 该 接口 的 run0 方 法 。 
以 下 是 主要 步骤 ; 
G@) 自 定义 类 并 实现 Runnable 接口 ， 实 现 run0 方 法 。 
@) 创建 Thread 对 象 ， 用 实现 Runnable 接口 的 对 象 作为 参数 实例 化 该 Thread 对 每。 
@) 调用 Thread 的 start0) 方 法 。 


class MyThread implements Runnable 
{// 创 建 线程 类 

public void run() 

{ 


System.out.println("Thread body"); 
} 
} 


public class Test 


{ 
public static void main(String[] args) 
MyThread thread=new MyThread(); 
Thread t=new Thread(thread); 
tstart0; /开启 线程 
} 
} 


2) 继承 Thread 类 ， 重 写 run 方法 。 
Thread 本 质 上 也 是 实现 了 Runnable 接口 的 一 个 实例 ， 它 代表 一 个 线程 的 实例 ， 并 且 ， 启 
动 线程 的 唯一 方法 就 是 通过 Thread 类 的 start0 方 法 。start() 方 法 是 一 个 native( 本 地 ) 方法 ， 
它 将 启动 一 个 新 线程 ， 并 执行 run0 方 法 Thread 中 提供 的 run0 方 法 是 一 个 空 方法 )。 这 种 方 
式 通 过 自 定义 类 直接 extends Thread， 并 重 写 ran0 方 法 ,就 可 以 启动 新 线程 并 执行 自己 定义 的 
run0 方 法 。 需 要 注意 的 是 ， 当 start0 方 法 调用 后 并 不 是 立即 执行 多 线程 代码 ， 而 是 使 得 该 线程 
变 为 可 运行 态 (Runnable)， 什 么 时 候 运 行 多 线程 代码 是 由 操作 系统 决定 的 。 
下 例 给 出 了 Thread 的 使 用 方法 。 
class MyThread extends Thread 
{创建 线程 类 
public void run() 


\ 


System.out.println("Thread body"); /线程 的 方法 体 
} 
} 


public class Test 


{ 


public static void main(String[] args) 


{ 


MyThread thread=new MyThread(); 
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thread.start0; /开启 线 程 


} 


3) 实现 Callable 接口 ， 重 写 call0 方 法 。 

Callable 对 象 实际 是 属于 Executor 框架 中 的 功能 类 ，Callable 接口 与 Runnable 接口 类 似 ， 
但 是 提供 了 比 Runnable 更 强大 的 功能 ， 主 要 表现 为 以 下 三 点 : 

QD Callable 可 以 在 任务 结束 后 提供 一 个 返回 值 ，Runnable 无 法 提供 这 个 功能 。 

@ Callable 中 的 call0 方 法 可 以 抛 出 异常 ， 而 Runnable 的 run() 方 法 不 能 抛 出 异常 。 

@ 运行 Callable 可 以 拿 到 一 个 Future 对 象 ，Future 对 象 表示 异步 计算 的 结果 。 它 提供 了 
给 查 计算 是 否 完成 的 方法 。 由 于 线程 属于 异步 计算 模型 ， 所 以 无 法 从 其 他 线程 中 得 到 方法 的 
返回 值 ， 在 这 种 情况 下 ， 就 可 以 使 用 Future 来 监视 目标 线程 调用 call0 方 法 的 情况 ， 当 调用 
Future 的 get0 方 法 以 获取 结果 时 ， 当 前 线程 就 会 阻塞 ， 直 到 call0 方 法 结束 返回 结果 。 

示例 代码 如 下 所 示 : 


import java.util.concurrent.*; 
public class CallableAndFuture 
/ 创建 线程 类 
public static class CallableTest implements Callable<String> 
{ 
public String call() throws Exception 
{ 
return "Hello World!"; 
} 
} 
public static void main(String[] args) 
{ 
ExecutorService threadPool = Executors.newSingleThreadExecutor(); 
// 启动 线程 
Future<String> future = threadPool.submit(new CallableTest()); 
try 
{ 
System.out.println("walting thread to finish"); 
System.out.println(future.get0); // 等 待 线程 结束 ， 并 获取 返回 结果 
} 
catch (Exception e) 
{ 
e.printStackTrace(); 
} 
} 
} 
上 述 程序 的 输出 结果 为 
waiting thread to finish 
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Hello World! 


的 。 


在 以 上 三 种 方式 中 ， 前 两 种 方式 线程 执行 完 后 都 没有 返回 值 ， 只 有 最 后 一 种 是 带 返 回 值 
当 需 要 实现 多 线程 时 ， 一 般 推 荐 实现 Runnable 接口 的 方式 ， 原 因 如 下 : 首先 ，Thread 类 


定义 了 多 种 方法 可 以 被 派生 类 使 用 或 重 写 , 但 是 只 有 run 方法 是 必须 被 重 写 的 , 在 run 方法 中 


实现 


这 个 线程 的 主要 功能 。 这 当然 是 实现 Runnable 接口 所 需 的 同样 的 方法 。 而 且 ， 很 多 Java 


开发 人 员 认 为 ， 一 个 类 仅 在 它们 需要 被 加 强 或 修改 时 才 会 被 继承 。 因 此 ， 如 果 没 有 必要 重 写 
Thread 类 中 的 其 他 方法 ， 那 么 通过 继承 Thread 的 实现 方式 与 实现 Runnable 接口 的 效果 相同 ， 


在 这 种 情况 下 最 好 通过 实现 Runnable 接口 的 方式 来 创建 线程 。 


3. 答案 : 本 题 考 察 的 是 递归 知识 。 
使 用 递归 时 ， 关 键 问题 是 要 明白 递归 表达 式 的 含义 以 及 递归 的 终止 条 件 。 
实现 代码 如 下 : 


public class Test 
public static long fac(int n) 
{ 
if(n> 1) 
return (n * fac(n - 1)); 
else 
return 1; 
} 
public static void main(String args[]) 
System.out.println(fac(6)); 
} 
} 
程序 的 运行 结果 为 
720 


4. 答案 : 观察 者 模式 (也 被 称 为 发 布 /订阅 模式 〉 提 供 了 避免 组 件 之 间 紧 密 粳 合 的 男 一 


种 方法 ， 它 将 观察 者 和 被 观察 的 对 象 分 离开 。 在 该 模式 中 ， 一 个 对 象 通过 添加 一 个 方法 (该 
方法 允许 另 一 个 对 象 ， 即 观察 者 注册 自己 ) 使 本 身 变 得 可 观察 。 当 可 观察 的 对 象 更 改 时 ， 它 


会 将 


这 种 
洲 


面 的 


~ 


消息 发 送 到 已 注册 的 观察 者 。 这 些 观 察 者 收 到 消息 后 所 执行 的 操作 与 可 观察 的 对 象 无 关 ， 
红 式 使 得 对 象 可 以 相互 对 话 ， 而 不 必 了 解 原因 。Java 语言 与 C# 语 言 的 事件 处 理 机 制 就 是 


用 的 此 种 设计 模式 。 


例如， 用户 界面 “同一 个 数据 可 以 有 多 种 不 同 的 显示 方式 ) 可 以 作为 观察 者 ， 业 务 数据 


是 被 观察 者 ， 当 数据 有 变化 后 会 通知 界面 ， 界 面 收 到 通知 后 ， 会 根据 自己 的 显示 方式 修改 界 


显示 。 面 向 对 象 设 计 的 一 个 原则 是 : 系统 中 的 每 个 类 将 重点 放 在 某 一 个 功能 上 ， 而 不 是 


限 ， 


其 他 方面 。 一 个 对 象 只 做 一 件 事情 ， 并 且 将 它 做 好 。 观 察 者 模式 在 模块 之 间 划 定 了 清晰 的 界 


提高 了 应 用 程序 的 可 维护 性 和 重用 性 。 设 计 类 图 如 图 1 所 示 。 
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人 
增加 和 删除 观察 者 的 主题 接口 所 有 观察 者 的 接口 


<<interface>> 
+addObserver0 Observer 
+updateO 
性 


+removeObserver() 
+notifyObservers() 


ConcreteObserver 


ConcretSubject 


实现 增加 和 删除 观察 者 ,实现 通知 所 有 观察 者 对 象 实际 的 观察 者 


图 1 设计 类 图 


下 面 给 出 一 个 观察 者 模式 的 示例 代码 ， 代 码 的 主要 功能 是 实 雪 
县 可 以 有 多 种 不 同 的 展示 方式 : 


上 


上 


见 天 气 预 报 ， 同 样 的 温度 信 


import java.util.ArrayList; 

interface Subject 

{ 
public void registerObserver(Observer 0); 
public void removeObserver(Observer 0); 
public void notifyObservers(); 


class Whether implements Subject 
private ArrayList<Observer>observers=new ArrayList<Observer>(); 
private float temperature; 
Override 
public void notifyObservers() { 
for(int 1=0;i<this.observers.size();i++) 


{ 
this.observers.get(i).update(temperature); 
} 
} 
(QOverride 


public void registerObserver(Observer 0) { 
this.observers.add(o); 

} 

Override 

public void removeObserver(Observer 0) { 
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this.observers.Temove(o); 


} 

public void whetherChange() { 
this.notifyObservers(); 

} 


public float getTemperature(){ 
return temperature; 

} 

public void setTemperature(float temperature) { 
this.temperature = temperature; 
notifyObservers(); 


interface Observer 


{ 


// 更 新 温度 
public void update(float temp); 


-~ 


class WhetherDisplayl implements Observer 
{ 
private float temprature; 
public WhetherDisplayl(Subject whether){ 
whether.registerObserver(this); 
} 
(QOverride 
public void update(float temp) { 
this.temprature=temp; 
display(); 
} 
public void display(){ 
System.out.println("displayl ****:"+this.temprature); 


class WhetherDisplay2 implements Observer 


{ 
private float temprature; 
public WhetherDisplay2(Subject whether) 


{ 

whether.registerObserver(this); 
} 
Override 


public void update(float temp) { 


this.temprature=temp; 
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display(); 
} 
public void display() 
{ 
System.out.println("display2----:"+this.temprature); 
} 


} 


public class Test 


{ 

public static void main(String[] args) 

{ 
Whether whether=new Whether(); 
WhetherDisplayl dl=new WhetherDisplayl(whether); 
WhetherDisplay2 d2=new WhetherDisplay2(whether); 
whether.setTemperature(27); 
whether.setTemperature(26); 

} 


} 


5. 答案 : 10 亿 条 记录 对 应 的 数据 量 在 GB 量 级 ， 对 于 普通 的 计算 机 来 讲 ,没有 这 么 大 的 
内 存 空 间 供 使 用 ， 因 此 ， 无 法 一 次 把 这 些 数据 信息 全 部 都 读 到 内 存 中 进行 处 理 ， 需 要 对 问题 
进行 分 解 ， 例 如 把 数据 分 成 100 份 ， 每 一 份 就 是 10MB 量 级 ， 基 本 上 放 入 内 存 无 压力 了 。 

把 这 10 亿 记 录 , 均 分 为 100 份 ， 把 每 份 的 第 一 条 记录 关键 字 和 此 记录 对 应 的 文件 偏 移 量 
先 扫 入 内 存 〈 类 似 索引 )， 这 里 需要 磁盘 随机 IO100 次 。 

这 样 可 以 马上 定位 出 指定 关键 字 所 在 的 记录 块 ， 把 相应 的 记录 块 拿 到 内 存 ， 二 分 查找 
即 可 。 


过 这 玉 入 、 东 知名 社交 平台 软件 工程 师 笔 试题 


一 、 单 项 选择 题 

1. 管 案 : DD。 

分 析 : 本 题 考察 的 是 进 制 转换 的 知识 。 

本 题 中 , 二 进 制 数 11101 对 应 的 十 进 制 数 表示 为 1*2^0 + 0*2^1 + 1*2^2 + 1*2^3 + 1*2^4 = 
29， 所 以 ， 选 项 D 正确 。 除 了 人 工 转换 外 ,在 Java 语言 中 ， 也 可 以 用 如 下 方法 将 一 个 二 进 制 
数 转换 为 十 进 制 数 : IntegervalueOft"11101",2) 。 

所 以 ， 本 题 的 答案 为 D。 

2. 答案 : A。 

分 析 : 本 题 考 察 的 是 Java 关键 字 的 知识 。 

对 于 选项 A，synchronized〔 同 步 的 ) 是 Java 语言 的 关键 字 ， 主 要 用 来 给 对 象 和 方法 或 者 
代码 块 加 锁 ， 当 它 锁 定 一 个 方法 或 者 一 个 代码 块 时 ， 同 一 时 刻 最 多 上 只 有 一 个 线程 执行 这 段 代 
码 。 当 两 个 并 发 线程 访问 同一 个 对 象 中 的 这 个 加 锁 同 步 代码 块 时 ， 同 一 时 间 上 只 能 有 一 个 线程 


也 
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执行 。 所以， 选项 A 正确 。 

对 于 选项 B，serialize 是 序列 化 的 意思 ， 所 谓 对 象 的 序列 化 指 的 是 把 对 象 转换 为 字 节 序 
列 的 过 程 ， 所 谓 对 象 的 反 序列 化 指 的 是 把 字 节 序列 恢复 为 对 象 的 过 程 。 通 常 ， 对 象 的 序列 化 
主要 有 以 下 两 种 用 途 : 中 将 对 象 的 字 节 序列 永久 地 保存 到 人 硬盘 上， 通常 存放 在 一 个 文件 中 
包 在 网 络 上 传送 对 象 的 字 节 序列 。 在 Java 语言 中 , 序列 化 通过 Serializable 接口 来 实现 。 所 以 ， 
选项 B 不 正确 。 

对 于 选项 C， 在 由 Java 语言 编写 的 程序 中 ， 有 时 候 为 了 提高 程序 的 运行 效率 ， 编 译 器 会 
做 一 些 优化 操作 ， 把 经 常 被 访问 的 变量 缓存 起 来 ， 程 序 在 读 取 这 个 变量 的 时 候 有 可 能 会 直接 
从 寄存 器 中 读 取 这 个 值 ， 而 不 会 去 内 存 中 读 取 。 这 样 做 的 一 个 好 处 是 提高 了 程序 的 运行 效率 ， 
但 当 遇 到 多 线程 编程 时 ， 变 量 的 值 可 能 被 其 他 线程 改变 了 ， 而 该 缓存 的 值 不 会 做 相应 的 改变 ， 
从 而 造成 应 用 程序 读 取 的 值 和 实际 的 变量 值 不 一 致 。 关 键 字 volatile 正好 能 够 解决 这 一 问题 ， 
被 关键 字 volatile 修饰 的 变量 编译 器 不 会 做 优化 ， 每 次 都 会 从 内 存 中 读 取 。 所 以 ， 选 项 C 不 
正确 。 

对 于 选项 D， 关 键 字 static 主要 有 以 下 两 种 作用 : 第 一 ， 为 某 特定 数据 类 型 或 对 象 分 配 单 
一 的 存储 空间 ， 而 与 创建 对 象 的 个 数 无 关 。 第 二 ， 和 希望 某 个 方法 或 属性 与 类 而 不 是 对 象 关联 
在 一 起 ， 也 就 是 说 ， 在 不 创建 对 象 的 情况 下 就 可 以 通过 类 来 直接 调用 方法 或 使 用 类 的 属性 。 
总 之 ， 被 static 修饰 的 属性 (方法 ) 是 类 的 属性 〈 方 法 )， 不 属于 任何 对 象 。 所 以 ， 选 项 D 不 
正确 


所 以 ， 本 题 的 答案 为 A。 

二 、 不 定 项 选择 题 

1. 答案 : C。 

分 析 : 本 题 考 察 的 是 Java 语言 构造 方法 的 知识 。 

对 于 选项 A， 类 中 的 构造 方法 是 可 以 省 略 的 ， 当 省 略 的 时 候 ， 编 译 器 会 提供 一 个 默认 的 
构造 方法 以 供 使 用 。 因 此 ， 选 项 A 错误 。 

对 于 选项 B， 构 造 方法 必须 与 类 名 相同 ， 但 是 方法 名 也 可 以 与 类 名 相同 。 如 下 例 所 示 ; 


public class Test{ 

public Test(){ 
System.out.println("construct ); 

} 

public void Test(){ 
System.out.println("call Test"); 

} 

public static void main(String[| args) { 
Test a 二 new Test(); /调用 构造 方法 
a.Test(); /调用 Test 方法 


My 


} 


程序 的 运行 结果 为 


construct 
call Test 
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因此 ， 选 项 B 错误 。 

对 于 选项 C， 当 一 个 对 象 被 new 的 时 候 必 定 会 调用 构造 方法 。 因 此 ， 选 项 C 正确 。 

对 于 选项 D， 由 于 构造 方法 也 可 以 重 载 ， 所 以 ， 一 个 类 可 以 定义 多 个 构造 方法 。 因 此 ， 
选项 DD 错误 。 

所 以 ， 本 题 的 答案 为 C。 

2. 答案 : A、B。 

分 析 : 本 题 考 察 的 是 Java 基本 语法 的 知识 。 

在 Java 语言 中 ，main 方法 是 程序 的 入 口 方法 ， 一 个 程序 要 想 运 行 必须 要 有 main 方法 ， 
但 是 只 有 满足 特定 条 件 的 main 方法 才能 作为 程序 的 入 口 方法 。 对 于 本 题 而 言 : 

对 于 选项 A， 由 于 Java 语言 是 纯 面 向 对 象 语言 ， 所 以 ， 所 有 的 属性 与 方法 都 必须 定义 在 
类 里 面 ， 而 且 ，main 方法 也 不 例外 。 因 此 ， 选 项 A 正确 。 

对 于 选项 B，Java 程序 可 以 定义 多 个 main 方法 ， 但 是 只 有 public static void main(String[] 
args) 方 法 才 是 Java 程序 的 入 口 方法 , 其 他 main 方法 都 不 是 , 并 且 这 个 入 口 方法 必须 被 定义 在 
类 名 与 文件 名 相同 的 被 public 修饰 的 类 中 ， 如 下 例 所 示 (Test.java): 


class T{ 
public static void main(String[] args) { 


System.out.println("T main"); 


} 


} 


public class Test { 
// 程序 入 口 方法 
public static void main(String[] args) { 


System.out.println("Test main"); 
1 
} 


} 
旦 序 的 运行 结果 为 


Ey 


Test main 


从 上 例 可 以 看 出 ， 这 个 程序 中 定义 了 多 个 main 方法 ， 但 是 只 有 满足 特定 条 件 的 main 方 
法 才能 作为 程序 的 入 口 方法 。 因 此 ， 选 项 B 正确 。 

对 于 选项 C， 在 Java 语言 中 ， 不 管 方法 体 里 有 几 条 语句 ， 所 有 的 方法 体 都 必须 用 大 括号 
介 括 起 来 。 因 此 ， 选 项 C 错误 。 

对 于 选项 D， 在 Java 语言 中 ， 一 个 文件 内 部 可 以 有 多 个 类 的 存在 ， 但 只 有 被 public 修饰 
的 类 的 名 字 与 文件 的 名 字 相 同 ， 其 他 类 的 名 字 可 以 根据 需求 随意 起 名 字 。 因 此 ,选项 D 错误 。 

所 以 ， 本 题 的 答案 为 A、B。 

3. 答案 : C。 

分 析 : 本 题 考 察 的 是 Java 关键 字 的 知识 。 

对 于 选项 A， 关 键 字 private 是 一 个 作用 域 修 饰 符 ， 被 关键 字 private 修饰 过 的 变量 或 方法 
只 有 当前 类 或 对 象 具 有 访问 权限 。 所 以 ， 选 项 A 不 正确 。 

对 于 选项 B， 在 Java 语言 中 ， 可 以 通过 把 类 或 者 类 中 的 某 些 方法 声明 为 abstract 来 表示 
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一 个 类 是 抽象 类 。 所 以 ， 选 项 B 不 正确 。 

对 于 选项 C， 被 final 修饰 的 变量 为 常量 ， 当 一 个 方法 被 声明 为 final 时 ， 该 方法 不 允许 任 
何 子 类 重 写 ， 当 一 个 类 被 声明 为 final 时 ， 此 类 不 能 被 继承 ， 所 有 方法 都 不 能 被 重 写 。 所 以 ， 
选项 C 正确 。 

对 于 选项 D， 关 键 字 static 主要 有 两 种 作用 : 第 一 ， 为 某 特定 数据 类 型 或 对 象 分 配 单 一 的 
存储 空间 ， 而 与 创建 对 象 的 个 数 无 关 ; 第 二 ， 和 希望 某 个 方法 或 属性 与 类 而 不 是 对 象 关联 在 一 
起 ， 也 就 是 说 ， 在 不 创建 对 象 的 情况 下 就 可 以 通过 类 来 直接 调用 方法 或 使 用 类 的 属性 。 即 被 
static 修饰 的 属性 (方法 ) 是 类 的 属性 〈 方 法 )， 不 属于 任何 对 象 。 所 以 ， 选 项 D 不 正确 。 

所 以 ， 本 题 的 答案 为 C。 

4. 答案 : A、B、C。 

分 析 : 本 题 考察 的 是 抽象 类 的 知识 。 

在 Java 语言 中 ， 关 键 字 abstract 主要 用 来 定义 抽象 类 或 抽象 方法 。 

对 于 选项 A， 在 Java 语言 中 ， 关 键 字 abstract 只 能 修饰 类 或 方法 ， 代 表 抽 象 方法 或 抽象 
类 。 所 以 ， 选 项 A 正确 。 

对 于 选项 B， 在 Java 语言 中 ， 关 键 字 final 可 以 用 来 修饰 类 、 方 法 和 变量 (包括 成 员 变 量 
和 局 部 变量 )。 具 体 而 言 ，final 具有 以 下 性 质 : QD 当 用 final 修饰 一 个 类 时 ， 表 明 这 个 类 不 外 
被 继承 ; 包 当 final 修饰 方法 时 ， 这 个 方法 不 能 被 子 类 重 写 ; @) 当 final 修饰 变量 时 ， 如 果 是 基 
本 数据 类 型 的 变量 ， 则 其 数值 一 旦 被 初始 化 之 后 便 不 能 更 改 ， 如 果 是 引用 类 型 的 变量 ， 则 在 
对 其 初始 化 之 后 便 不 能 再 让 其 指向 另 一 个 对 象 。 所 以 ， 被 final 修饰 的 方法 是 不 能 被 继承 的 ， 
因此 ， 该 方法 不 能 为 abstract。 所 以 ， 选 项 B 正确 。 

对 于 选项 C， 由 于 抽象 类 中 存在 没有 方法 体 的 方法 ， 因 此 ， 不 能 被 实例 化 。 所 以 ,选项 C 


加 | 


CC 


A 


对 于 选项 D， 子 类 可 以 实现 超 类 所 有 的 方法 〈 这 个 子 类 能 被 实例 化 )， 子 类 也 可 以 是 一 个 抽 
象 类 ， 此 时 这 个 子 类 可 以 实现 超 类 的 abstract 方法 ， 也 可 以 不 实现 。 所 以 ， 选 项 D 错误 。 

所 以 ， 本 题 的 答案 为 A、B、C。 

5. 管 案 : C。 

分 析 : 本 题 考察 的 是 标识 符 的 知识 。 
在 Java 语言 中 ， 变 量 名 、 方 法 名 和 数组 名 统称 为 标识 符 ，Java 语言 规定 标识 符 只 能 由 字 
母 (a~z，A~Z)、 数 字 (0~~9)、 下 划 线 (_)〉 和 $ 组 成 ， 并 且 标 识 符 的 第 一 个 字符 必须 是 字 
母 、 下 划 线 或 $8。 而 且 ， 标 识 符 也 不 能 包含 空白 字符 (换行 符 、 空 格 和 制 表 符 )。 此 外 ，Java 
语言 的 关键 字 也 不 能 作为 标识 符 来 使 用 。 

以 上 这 四 个 选项 都 符合 变量 的 命名 规划， 但是， 选项 C 中 的 void 是 Java 语言 的 关键 字 ， 
因此 ， 它 不 能 被 用 作 标 识 符 使 用 。 所 以 ， 选 项 C 不 正确 。 

所 以 ， 本 题 的 答案 为 C。 

6. 答案 : B。 

分 析 : 本 题 考 察 的 是 Java 语言 知识 。 

对 于 选项 A， 只 要 类 中 定义 了 构造 方法 (不 管 有 没有 参数 )，JVM 都 不 会 提供 默认 构造 
方法 了 。 因 此 ， 选 项 A 错误 。 
对 于 选项 B， 变 量 的 作用 域 指 的 是 可 以 使 用 此 变量 的 名 称 来 引用 它 的 程序 区 域 ， 变 量 声 
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明 在 程序 中 的 位 置 决定 了 该 变量 的 作用 域 。 局 部 变量 在 方法 或 方法 的 一 个 代码 块 中 声明 ， 它 
的 作用 域 为 它 所 在 的 代码 块 《代码 块 是 整个 方法 或 方法 中 的 某 块 代码 ， 即 以 括号 他 包括 的 代 
码 )。 所以， 局 部 变量 仪 在 定义 它 的 方法 或 块 内 可 见 。 因 此 ， 选 项 B 正确 。 

对 于 选项 C， 在 使 用 其 他 类 的 方法 的 时 候 ， 需 要 用 “类 名 .方法 ”来 引用 ， 不 能 直接 通过 
方法 名 字 引 用 。 因 此 ， 选 项 C 错误 。 

对 于 选项 D， 只 有 被 static 修饰 的 变量 才 是 类 的 成 员 变 量 ， 但 是 当 类 中 的 变量 被 private 
修饰 时 ， 其 他 类 是 无 法 直接 使 用 的 。 因 此 ， 选 项 D 错误 。 

所 以 ， 本 题 的 答案 为 B。 

7. 答案 : B。 

分 析 : 本 题 考察 的 是 前 置 自 增 运算 符 ++ 和 后 置 自 增 运算 符 ++ 的 知识 。 

在 编程 的 时 候 ， 经 常会 用 到 变量 的 自 增 或 自 减 操作 ， 尤 其 在 循环 语句 中 用 得 最 多 。 以 自 
增 为 例 ， 有 两 种 自 增 方式 ， 前 置 与 后 置 ， 即 ++i 和 过 +， 它 们 的 不 同 点 在 于 后 置 的 it+ 是 在 程 
序 执行 完毕 后 自 增 ， 而 前 置 的 ++i 是 在 程序 开始 执行 前 进行 自 增 。 

对 于 本 题 而 言 ， 整 型 变量 i 被 初始 化 为 6， 因 此 ， 第 一 个 输出 为 6， 第 二 个 输出 +， 因 
为 这 是 后 置 + 操作 ， 因 此 ， 输 出 结果 为 6， 输 出 后 i 的 值 变 为 7， 故 最 后 一 个 输出 操作 的 值 为 
7。 所 以 ， 选 项 B 正确 。 

所 以 ， 本 题 的 答案 为 B。 

8. 答案 : A。 

分 析 : 本 题 考 察 的 是 super 关键 字 的 知识 。 

在 Java 语言 中 ， 关 键 字 this 指 的 是 对 当前 对 象 的 引用 ， 关 键 字 super 指 的 是 当前 对 象 里 
掉 的 父 对 象 的 引用 , 当 引 用 当前 对 象 的 某 个 方法 或 某 个 成 员 时 , 通常 会 使 用 this, 而 通过 super 
可 以 调用 父 类 的 构造 方法 、 父 类 的 方法 和 属性 。 如 下 例 所 示 : 


尘 | 


class Base 
{ 
public int status=0; 
Base(int status) 
{ 
this.status=status; 
} 
public void print() 
{ 
System.out.println("base"); 
} 
} 
class Sub extends Base 
{ 
public int status; 
Sub(int status) 
{ 
super(status-1); 
this.status=status; 
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} 
public void printSub() 
{ 
System.out.println("sub"); 
System.out.println("status="+status); 
} 
public void printBase() 
{ 
super.print(); 
System.out.println("status="+Super.status); 
} 
} 
public class Test 
{ 
public static void main(String args[]) 
{ 
Sub s=new Sub(2); 
s.printBase(); 
s.printSub(); 
} 
} 
程序 的 运行 结果 为 
base 
status=1 
sub 
status=2 


通过 以 上 分 析 可 知 ， 选 项 A 正确 ， 选 项 B 和 选项 C 错误 ， 对 于 选项 D， 
父 类 的 引用 ， 不 能 表示 父 类 的 父 类 。 因 此 ， 选 项 D 错误 。 

所 以 ， 本 题 的 答案 为 A。 

9. 答案 A、B、D。 

分 析 : 本 题 考 察 的 是 Java 语言 中 字符 串 相 关 知 识 。 


| 


super 内 能 表 


EA 


在 Java 语言 中 ，String 是 不 可 变 类 ， 也 就 是 说 ，String 对 象 一 旦 被 创建 ， 字 符 串 的 内 


容 将 不 能 被 改变 ， 而 StringBuffer 是 可 变 类 ， 当 对 象 被 创建 后 ,仍然 可 以 对 


字符 串 的 内 容 


进行 修改 。 由 于 String 是 不 可 变 类 ， 因 此 ， 它 适合 在 需要 被 共享 的 场合 ! 


个 字符 串 经 常 需要 被 修改 时 ， 最 好 使 用 StringBuffer 来 实现 。 如 果 使 用 String 来 保存 一 个 


经 常 被 修改 的 字符 串 ， 在 字符 串 被 修改 时 ， 会 比 StringBuffer 多 很 多 附加 


的 操作 ， 同 时 生 


成 很 多 无 用 的 对 象 ， 由 于 这 些 无 用 的 对 象 会 被 垃圾 回收 器 回收 ， 所 以 会 影响 程序 的 性 能 。 在 
规模 小 的 项 目 中 这 个 影响 很 小 ， 但 是 在 一 个 规模 大 的 项 目 中 ， 这 会 对 程序 的 运行 效率 带 来 很 


大 的 影响 。 


String 字符 串 修 改 实现 的 原理 如 下 : 当 使 用 String 类 型 来 对 字符 串 进 行 修改 时 ， 其 实现 方 


的 toString 方法 把 结果 返回 。 举 例如 下 : 


108 


法 是 首先 创建 一 个 StringBuffer， 然 后 调用 StringBuffer 的 append 方法 ， 最 后 调用 StringBuffer 


String s="“Hello”; 
S+=“World”; 


以 上 代码 与 下 述 代码 等 价 : 


String s="“Hello”; 

StringBuffer sb=new StringBuffer(s); 
s.append(“World”’); 

s=sb.toString(); 


此 可 以 看 出 ， 上 述 过 程 比 使 用 StringBuffer 多 了 一 些 附加 的 操作 ， 同 时 也 生成 了 一 些 临 
时 的 对 象 ， 这 样 会 导致 程序 的 执行 效率 降低 。 

StringBuilder 也 是 可 以 被 修改 的 字符 串 ， 它 与 StringBuffer 类 似 ， 都 是 字符 溃 缓 冲 区 ， 但 
StringBuilder 不 是 线程 安全 的 ， 如 果 只 是 在 单线 程 中 使 用 字符 串 缓冲 区 ， 那 么 StringBuilder 
的 效率 会 更 高 些 。 因 此 ， 在 上 只 有 单线 程 访问 的 时 候 ， 可 以 使 用 StringBuilder， 当 有 多 个 线程 访 
问 时 ， 最 好 使 用 线程 安全 的 StringBuffer。 因 为 StringBuffer 必要 时 可 以 对 这 些 方法 进行 同步 ， 
所 以 ， 任 意 特定 实例 上 的 所 有 操作 就 好 像 是 以 串 行 顺序 发 生 的 ， 该 顺序 与 所 涉及 的 每 个 线程 
进行 的 方法 调用 顺序 一 致 。 
在 执行 效率 方面 ，StringBuilder 最 高 ，StringBuffer 次 之 ，String 最 低 ， 鉴 于 这 一 情况 ， 一 般 
而 言 ， 如 果 要 操作 的 数据 量 比较 小 ， 可 以 使 用 String 类 ， 如 果 是 在 单线 程 下 操作 大 量 数据 ， 优 先 
使 用 StringBuilder 类 ， 如 果 是 在 多 线程 下 操作 大 量 数 据 ， 优 先 考虑 StringBuffer 类 。 

从 以 上 分 析 可 知 ，StringBuilder 不 是 线程 安全 的 。 所 以 ， 选 项 A、 选 项 B 与 选项 DD 正确 。 

所 以 ， 本 题 的 答案 为 A、B、D。 

10. 答案 , B、C、D。 

分 析 : 本 题 考 察 的 是 Java 语言 中 基本 类 型 知识 。 

Java 语言 一 共 提 供 了 8 种 原始 的 数据 类 型 (byte、short、int、long、float、double、char 
和 boolean)， 这 些 数据 类 型 不 是 对 象 ， 而 是 Java 语言 中 不 同 于 类 的 特殊 类 型 ， 这 些 基本 类 型 
的 数据 变量 在 声明 之 后 就 会 立刻 在 栈 上 分 配 内 存 空间 。 此 外 ，Java 语言 还 提供 了 这 些 原 始 数 
据 类 型 的 包装 类 〈 字 符 类 型 Character， 布 尔 类 型 Boolean， 数 值 类 型 Byte、Short、Integer、 
Long、 Float、Double)。 

本 题 中 ，Byte、Float 是 包装 类 类 型 ，String 是 存储 字符 串 的 类 , 只 有 int 是 基本 数据 类 型 。 
所 以 ， 选 项 B、 选 项 C 与 选项 DD 正确 。 

所 以 ， 本 题 的 答案 为 B、C、D。 

11. 答案 : D。 

分 析 : 本 题 考 察 的 是 线程 相关 方法 的 知识 。 

对 于 选项 A，wait0 方 法 是 一 种 使 线程 暂停 执行 的 方法 ， 例 如 ， 当 线程 交互 时 ， 如 果 线 程 
对 一 个 同步 对 象 发 出 了 一 个 waitO 调 用 请 求 ， 那 么 该 线程 会 暂停 执行 ， 被 调 对 象 进入 等 待 状态 , 直 
到 被 唤醒 〈 通 常 使 用 notify 方法 唤醒 ) 或 等 待 时 间 超 时 。 所 以 ， 选 项 A 错误 。 

对 于 选项 B，sleep() 方 法 的 作用 是 使 当前 运行 的 线程 休 卢 指定 的 时 间 。 所 以 ， 选 项 了 B 错误 。 

对 于 选项 C， 可 以 使 用 stop0 方 法 来 终止 线程 的 执行 。 当 使 用 Thread.stop() 方 法 来 终止 线 
星 时 ， 它 会 释放 已 经 锁定 的 所 有 的 监视 资源 。 如 果 当 前 任何 一 个 受 这 些 监 视 资源 保护 的 对 象 


> 
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处 于 一 个 不 一 致 的 状态 ， 其 他 的 线程 将 会 看 到 这 个 不 一 致 的 状态 ， 这 可 能 会 导致 程序 执行 的 
不 确定 性 ， 并 且 这 种 问题 很 难 被 定位 。 因 此 ， 不 推荐 使 用 。 所 以 ， 选 项 C 错误 。 
对 于 选项 D，suspend() 方 法 就 是 将 一 个 线程 挂 起 〈 和 暂停)， 并 且 不 会 自动 恢复 ， 必 须 通过 调用 


对 应 的 resume0 方 法 ， 才 能 使 得 线程 重新 进入 可 执行 状态 。 所 以 ， 选 项 D 正确 。 


所 以 ， 本 题 的 答案 为 D。 
12. 答案 : B。 
分 析 : 本 题 考察 的 是 Java 语言 中 


异常 处 理 的 知识 。 


在 Java 语言 的 异常 处 理 中 , finally 语句 块 的 作用 就 是 为 了 保证 无 论 出 现 什 么 情况 , finally 


语句 块 里 的 代码 一 定 会 被 执行 。 由 于 : 


程序 执行 到 retur 语句 的 时 候 就 意味 着 结束 对 当前 方 


法 的 调用 并 跳出 这 个 方法 体 ， 因 此 ， 任 何 语句 要 执行 都 只 能 在 return 语句 前 执行 《除非 碰 到 


exit 方法 )， 所 以 ，finally 块 里 的 代码 也 是 在 retum 前 执行 的 。 此 外 ， 如 果 try-finally 或 者 
catch-finally 中 都 有 return 语句 ， 则 finally 块 中 的 return 语句 将 会 覆盖 别处 的 return 语句 ， 最 


终 返 回 到 调用 者 那里 的 是 finally 中 return 的 值 。 


对 于 本 题 而 言 ， 在 调用 testException 方法 时 不 会 抛 出 异常 ， 虽 然 testException 方法 体内 


~ 


调用 return 返回 这 个 方法 ， 


因此 ， 选 项 B 正确 。 
所 以 ， 本 题 的 答案 为 B。 

13. 答案 : D。 

分 析 : 本 题 考 察 的 是 Java 垃圾 回 


日 是 Java 虚拟 机 要 保证 finally 块 的 代码 必须 执行 ， 因 此 ， 在 调用 
testException 方法 的 时 候 会 输出 finally， 接 着 方法 调用 结束 后 ， 在 main 方法 中 会 输出 finished。 


收 知识 。 


在 Java 语言 中 ，GC (Garbage Collection， 垃 圾 回收 ) 是 一 个 非常 重要 的 概念 ， 它 的 主要 


作用 是 回收 程序 中 不 再 使 用 的 内 存 。 在 使 用 C/C++ 语言 进行 程序 开发 的 时 候 ， 开 发 人 员 必 须 


非常 仔细 地 管理 好 内 存 的 分 配 与 释放 ， 


如 果 筷 记 或 者 错误 地 释放 内 存 往 往 会 导致 程序 运行 不 正 


确 甚至 是 程序 的 崩溃 。 为 了 减轻 开发 人 员 的 工作 ， 同 时 增加 系统 的 安全 性 与 稳定 性 ，Java 语言 
提供 了 垃圾 回收 器 来 自动 检测 对 象 的 作用 域 ， 实 现 自 动 地 将 不 再 被 使 用 的 存储 空间 释放 掉 。 


在 Java 语言 中 ， 释 放 掉 占 据 的 内 


存 空 间 是 由 GC 完成 的 ， 程 序 员 无 法 直接 强制 释放 存储 


空间 ， 当 一 个 对 象 不 被 使 用 的 时 候 ，GC 会 将 该 对 象 标记 为 垃圾 ， 会 在 后 面 一 个 不 确定 的 时 间 
内 回收 垃圾 〈 程 序 员 无 法 控制 这 个 时 间 )。 

给 对 象 引用 赋值 为 null， 并 且 该 对 象 无 其 他 引用 ，GC 会 标记 该 对 象 为 垃圾 ， 会 在 后 面 一 
个 不 确定 的 时 间 内 回收 垃圾 。 所 谓 不 确定 是 指 什么 时 间 回 收 ， 程 序 员 无 法 控制 。 

本 题 中 ， 对 于 选项 A， 开 发 人 员 可 以 通过 调用 System.gc(0) 方 法 来 通知 垃圾 回收 器 运行 ， 
但 是 JVM 也 并 不 能 保证 垃圾 回收 器 马上 就 会 运行 。 因 此 ， 选 项 A 错误 。 

对 于 选项 B，Java 语言 没有 提供 free〈 和 释放) 方法。 因此， 选项 B 错误 。 

对 于 选项 C， 当 把 对 象 的 引用 设置 为 null 时 ，GC 会 标记 该 对 象 为 垃圾 ， 会 在 后 面 一 个 不 


总 


对 于 选项 D， 程 序 员 无 法 明确 强 
所 以 ， 本 题 的 答案 为 D。 
14. 答案 : A、B、C。 


上 定 的 时 间 内 回收 垃圾 。 因 此 ， 选 项 C 错误 。 


出 垃圾 回收 器 运行 。 因 此 ， 选 项 D 正确 。 


分 析 : 本 题 考察 的 是 Spring 框架 知识 。 
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和 \， 解 篇 


Spring 是 一 个 J2EE 的 框架 ， 这 个 框架 提供 了 对 轻 量 级 的 IoC (Inverse of Control， 控 制 反 
转 ， 有 时 候 也 被 叫 作 依 赖 注入 ) 良好 的 支持 ， 同 时 也 提供 了 对 AOP (Aspect Oriented 
条 问 切面 编程 》 技 术 非 常 好 的 封装 。 相 比 其 他 框架 ，Spring 框架 的 设计 更 加 模 
块 化 ， 框 架 内 的 每 个 模块 都 能 完成 特定 的 工作 ， 而 且 各 个 模块 都 可 以 独立 地 运行 ， 不 会 相互 
牵制 。 因 此 ， 在 使 用 Spring 框架 的 时 候 ， 开 发 人 员 可 以 使 用 整个 框架 ， 也 可 以 只 使 用 框架 内 
的 一 部 分 模块 ， 例 如 可 以 只 使 用 Spring AOP 模块 来 实现 日 志 管 理 功能 ， 而 不 需要 使 用 其 他 
模块 。 
具体 而 言 ，Spring 框架 主要 由 7 个 模块 组 成 ， 它 们 分 别 是 Spring AOP、Spring ORM、Spring 
DAO、Spring Web、Spring Context、Spring Web MVC 和 Spring Core 等 。 具 体 如 图 2 所 示 。 


Spring ORM Spring Web 
Spring AOP 
Spring DAO Spring Context 


Spring Core 


图 2 Spring 框架 


Programming， 


Spring Web MVC 


各 个 模块 的 作用 见 表 5。 


表 5 各 个 模块 的 作用 
模 块 描述 


Spring AOP 采用 了 面向 切面 编程 的 思想 ， 使 Spring 框架 管理 的 对 象 支持 AOP， 同 时 这 个 模块 也 提供 了 事务 
es 管理 ， 可 以 不 依赖 具体 的 EJB 组 件 ， 就 可 以 将 事务 管理 集成 到 应 用 程序 中 
Spring ORM 提供 了 对 现 有 的 ORM 框架 的 支持 ， 例 如 Hibemate、JDO 等 
提供 了 对 DAO (Data Access Object， 数 据 访 问 对 象 ) 模式 和 JDBC 的 支持 。DAO 可 以 实现 将 业 
Spring DAO 务 罗 辑 与 数据 库 访问 的 代码 分 离 , 从 而 降低 代码 的 耦合 度 。 通过 对 JDBC 的 抽象 , 简化 了 开发 工作 ， 
同时 简化 了 对 异常 的 处 理 〈 可 以 很 好 地 处 理 不 同 数据 库 厂 商 抛 出 的 异常 ) 
Sorine We 提供 了 Servlet 监听 器 的 Context 和 Web 应 用 的 上 下 文 。 同 时 还 集成 了 一 些 现 有 的 Web 框架 ， 
ee 例如 Struts 
pin Conteixt 扩展 核心 容器 ， 提 供 了 Spring 上 下 文 环境 ， 给 开发 人 员 提 供 了 很 多 非常 有 用 的 服务 ， 例 如 国际 
有 化 、Email 和 JNDI 访问 等 
Spring Web MVC 提供 了 一 个 构建 Web 应 用 程序 的 MVC 的 实现 
Spring 框架 的 核心 容器 ， 它 提供 了 Spring 框架 的 基本 功能 。 这 个 模块 中 最 主要 的 一 个 组 件 为 
Spring Core BeanFactory, 它 使 用 工厂 模式 来 创建 所 需 的 对 象 。 同时 BeanFactory 使 用 IOC 思想 , 通过 读 取 XML 
es 文件 的 方式 来 实例 化 对 象 ， 可 以 说 BeanFactory 提供 了 组 件 生命 周期 的 管理 ， 组 件 的 创建 、 装 配 以 


及 销毁 等 功能 


通过 以 上 分 析 可 以 看 出 ， 选 项 A、 选 项 B 与 选项 C 的 描述 都 是 正确 的 。 对 于 选项 D， 
Spring 并 没有 提供 日 志 系 统 , 需要 根据 需求 使 用 AOP 的 方式 , 借助 Spring 与 日 志 系 统 log4j 
实现 自己 的 日 志 功 能 。 因 此 ， 选 项 DD 错误 。 

所 以 ， 本 题 的 答案 为 A、B、C。 

15. 答案 : A、B。 

分 析 : 本 题 考察 的 是 堆 的 知识 。 
堆 是 一 种 特殊 的 树 形 结构 ， 有 大 顶 堆 和 小 顶 堆 两 种 。 大 顶 堆 (小 顶 堆 ) 的 特点 是 根 结 点 
的 值 最 大 (最 小 )， 且 根 结 点 的 子 树 也 为 一 个 大 顶 堆 〈 小 顶 堆 )。 
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对 于 选项 A， 完 全 二 又 树 是 指 除 最 后 一 层 外 ， 每 一 层 上 的 结 点 数 均 达 到 最 大 值 ; 在 使 用 
的 时 候 堆 是 采用 数组 来 存储 的 ， 因 此 ， 它 满足 完全 二 又 树 的 特点 。 所 以 ， 选 项 A 正确 。 

对 于 选项 B, 平衡 二 叉 树 (Balanced Binary Tree) 又 被 称 为 AVL 树 (有 别 于 AVL 算法 )， 
具有 以 下 性 质 : 它 是 一 棵 空 树 或 它 的 左右 两 个 子 树 的 高 度 差 的 绝对 值 不 超过 1， 并 且 左 右 两 
棵 子 树 都 是 一 棵 平衡 二 又 树 。 由 于 完全 二 又 树 一 定 满足 平衡 二 又 树 的 性 质 。 所 以 ， 选 项 B 
正确 


对 于 选项 C， 排 序 二 又 树 有 如 下 性 质 : 
1) 若 左 子 树 不 为 空 ， 则 左 子 树 上 所 有 结 点 的 值 均 小 于 它 的 根 结 点 的 值 。 
2) 知 右 子 树 不 为 空 ， 则 右 子 树 上 所 有 结 点 的 值 均 大 于 或 等 于 它 的 根 结 点 的 值 。 
3) 左 、 右 子 树 也 分 别 为 二 又 排序 树 。 
4) 没有 键 值 相等 的 结 点 。 
显然 ， 扒 不 满足 这 个 性 质 。 所 以 ， 选 项 C 是 错误 的 。 
对 于 选项 D， 满 二 又 树 是 指 树 中 除 最 后 一 层 无 任何 子 结 点 外 ， 每 一 层 上 的 所 有 结 点 都 有 
两 个 子 结 点 的 二 叉 树 。 满 二 又 树 中 结 点 的 个 数 为 1、3、7 等 特殊 的 数字 ， 而 堆 中 的 结 点 可 以 
是 任意 的 ， 因 此 ， 不 能 保证 堆 是 个 满 二 义 树 。 所 以 ， 选 项 DD 不 正确 。 

所 以 ， 本 题 的 答案 为 A、B。 

16. 答案 ， A、C、D。 

分 析 : 本 题 考 察 的 是 依赖 注入 的 知识 。 

IoC 〈JInverse of Control， 控 制 反 转 ) 有 时 候 也 被 叫 作 依赖 注入 ， 是 一 种 降低 对 象 之 间 耦 
合 关 系 的 设计 思想 。 一 般 而 言 ， 在 分 层 体系 结构 中 ， 都 是 上 层 调 用 下 层 的 接口 ， 上 层 依赖 于 
下 层 的 执行 ， 即 调用 者 依赖 于 被 调用 者 。 而 通过 ToC 方式 ， 使 得 上 层 不 再 依赖 于 下 层 的 接口 ， 
即 通过 采用 一 定 的 机 制 来 选择 不 同 的 下 层 实 现 ， 完 成 控制 反 转 ， 使 得 由 调用 者 来 决定 被 调用 
者 。IoC 通过 注入 一 个 实例 化 的 对 象 来 达到 解 耦 和 的 目的 。 使 用 这 种 方法 后 ， 对 象 不 会 被 显 式 
地 调用 ， 而 是 根据 需求 通过 IoC 容器 (例如 Spring) 来 提供 。 
采用 IoC 机 制 能 够 提高 系统 的 可 扩展 性 ， 如 果 对 象 之 间 通 过 显 式 的 调用 进行 交互 ， 那 么 
会 导致 调用 者 与 被 调用 者 存在 着 非常 紧密 的 联系 ， 其 中 一 方 的 改动 将 会 导致 程序 出 现 很 大 的 
改动 ， 例 如 ， 要 为 一 家 卖 茶 的 商店 提供 一 套 管理 系统 ， 在 这 家 商店 刚 开 业 的 时 候 只 卖 绿 茶 
(Green Tea)， 随 着 规模 的 扩大 或 者 根据 具体 销售 量 ， 未 来 可 能 会 随时 改变 茶 的 类 型 ， 例 如 红 
茶 (Black Tea) 等 ， 传 统 的 实现 方法 会 针对 茶 抽 象 化 一 个 基 类 ， 绿 茶 类 只 需要 继承 自 该 基 类 
即 可 。 如 图 3 所 示 。 


GreenTea 


图 3 茶 的 继承 
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采用 该 实现 方法 后 , 在 需要 使 用 Green Tea 的 时 候 , 只 需要 执行 以 下 代码 即 可 : Abstract Teat 
=hew Green Tea0， 当 然 ， 这 种 方法 是 可 以 满足 当前 设计 要 求 的。 但 是 该 方法 的 可 扩展 性 不 好 ， 
存在 着 不 恰当 的 地 方 , 例如 ， 当 商家 发 现 绿茶 的 销售 并 不 好 ,决定 开始 销售 红茶 (Black Tea) 时 ， 
那么 上 只 需要 实现 一 个 Black Tea 类 ， 并 且 让 这 个 类 继承 自 Abstract Tea 即 可 。 但 是 ， 在 系统 中 所 
有 用 到 Abstract Teat= new Green Tea0 的 地 方 ， 都 需要 被 改 为 Abstract Teat= new Black Tea0， 而 
这 种 创建 对 象 实例 的 方法 往往 会 导致 程序 的 改动 量 非常 大 。 

那么 怎样 才能 增强 系统 的 可 扩展 性 呢 ? 此 时 可 以 使 用 设计 模式 中 的 工厂 模式 将 创建 对 象 
的 行为 包装 起 来 ， 实 现 方法 如 图 4 所 示 。 


+get Tea() 


和 AV 


Green Tea 


' 
ooo- 


图 4 工厂 模式 

通过 以 上 方法 ， 可 以 把 创建 对 象 的 过 程 委托 给 TeaFatory 来 完成 ， 在 需要 使 用 Tea 对 象 的 
时 候 ， 只 需要 调用 Factory 类 的 get Tea 方法 即 可 ， 具 体 创 建 对 象 的 逻辑 在 TeaFactory 中 来 实现 ， 
那么 当 商家 需要 把 绿茶 替换 为 红茶 的 时 候 ， 系 统 中 只 需要 改动 TeaFactory 中 创建 对 象 的 逻辑 即 可 。 
当 采 用 了 工厂 模式 后 ， 只 需要 在 一 个 地 方 做 改动 就 可 以 满足 要 求 ， 从 而 增强 了 系统 的 可 扩展 性 。 
虽然 说 采用 工厂 设计 模式 后 增强 了 系统 的 可 扩展 性 ， 但 是 从 本 质 上 来 讲 ， 工 厂 模式 只 不 
把 程序 中 会 变动 的 逻辑 移动 到 工厂 类 里 面 了 ， 当 系统 中 的 类 较 多 的 时 候 ， 在 系统 扩展 时 
经 常 改动 工厂 类 中 的 代码 。 而 采用 IoC 设计 思想 后 ， 程 序 将 会 有 更 好 的 可 扩展 性 ， 下 面 
介绍 Spring 框架 在 采用 IoC 后 的 实现 方法 ， 如 图 5 所 示 。 


过 
需 


| 
征 
要 
开 
2 


主 


Ioc 容 器 通过 xml 配 置 文件 来 er Tee 
加 载 被 调用 对 象 | 
和 


Black Tea | 
| | | 
Ee | 


| 


Green Tea 


图 5 IoC 设计 思想 

Spring 容器 将 会 根据 配置 文件 来 创建 调用 者 对 象 〈(Sale )， 同 时 将 被 调用 的 对 和 象 
(AbstractTea 的 子 类 ) 的 实例 化 对 象 通过 构造 方法 或 set 方法 的 形式 注入 到 调用 者 对 象 中 。 
首先 ， 创 建 名 为 SpringConfig.xml 的 文件 。 


<beans> 


<bean id=”sale” class=”Sale” singleton= "false 


<constrctor-arg> 
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<ref bean= tea /> 

</constrctor-arg> 

</bean> 

<bean id=”tea” class=”BlueTea” singleton= false”> 


</beans> 


在 实现 Sale 类 的 时 候 ， 需 要 按照 如 下 方式 实现 : 


class Sale{ 

private AbstractTea t; 

public Sale(AbstractTea t){ 
this.t=t; 


a 


/ 
} 


其 他 方法 就 可 以 使 用 t 了 


当 Spring 容器 在 创建 Sale 对 象 的 时 候 ， 根 据 配置 文件 SpringConfig.xml 就 会 创建 一 个 


Blue Tea 的 对 象 ， 作 为 Sale 构造 方法 的 参数 。 当 需要 把 Blue Tea 改 为 Black Tea 时 ， 只 需要 修 
改 上 述 配置 文件 即 可 ， 而 不 需要 修改 代码 。 


在 需要 Sale 的 时 候 ， 可 以 通过 如 下 方式 来 创建 Sale 对 象 : 


ApplicationContext xtx=new FileSystemXmlApplicationContext(" SpringConfig.xml”); 
Sale s=(Sale)ctx.getBean(‘‘sale”’); 


上 例 中 ,Spring 采用 IoC 的 方式 来 实现 将 实例 化 的 对 象 注入 到 开发 人 员 自 定义 的 对 象 中 


-> 


TD 


有 和 较 强 的 可 扩展 性 。 


具体 而 言 ，IoC 主要 有 以 下 几 个 方面 的 优点 : 
1) 通过 IoC 容器 ， 开 发 人 员 不 需要 关注 对 象 是 如 何 被 创建 的 ， 同 时 ， 增 加 新 类 也 非常 方 


便 ， 只 需要 修改 配置 文件 即 可 实现 对 象 的 热 插 拔 。 


测试 。 


作 value。 两 者 具有 许多 相似 之 处 ， 但 也 有 很 多 不 同 之 处 。 以 下 重点 介绍 两 者 的 不 同 之 处 ， 具 


2) IoC 容器 可 以 通过 配置 文件 来 确定 需要 注入 的 实例 化 对 象 ， 因 此 ， 非 常 便于 进行 单元 


尽管 如 此 ，IoC 也 有 上 自身 的 缺点 ， 有 具体 表现 为 如 下 两 点 : 

1) 对 象 是 通过 反射 机 制 实例 化 出 来 的 ， 因 此 ， 会 对 系统 的 性 能 有 一 定 的 影响 。 

2) 创建 对 象 的 流程 变 得 比较 复杂 。 

通过 以 上 分 析 可 知 ， 只 有 选项 B 描述 错误 ， 注 入 降低 了 组 件 之 间 的 耦合 性 ， 而 不 是 使 组 


件 之 间 相 互 依赖 。 


所 以 ， 本 题 的 答案 为 A、C、D。 

17. 答案 : A、C、D。 

分 析 : 本 题 考察 的 是 Hashtable 和 HashMap 知识 。 

HashMap 和 Hashtable 通过 对 象 来 进行 索引 ， 用 来 索引 的 对 象 叫 作 key， 其 对 应 的 对 象 叫 


体 而 言 ， 体 现在 以 下 几 个 方面 ; 


1) 它们 都 实现 了 Map 接口 ，HashMap 允许 空 (null) 键 值 (key) (但 需要 注意 的 是 ， 最 


多 只 允许 一 条 记录 的 键 为 null， 不 允许 多 条 记录 的 值 为 null)， 而 Hashtable 不 允许 。 
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2) HashMap 把 Hashtable 的 contains 方法 去 挤 了 ， 改 成 containsvalue 和 containsKey。 因 
为 contains 方法 容易 引起 误解 。Hashtable 继承 自 Dictionary 类 ， 而 HashMap 继承 自 AbstractMap 类 。 

3) Hashtable 的 方法 是 线程 安全 的 ， 而 HashMap 不 是 线程 安全 的 。 当 多 个 线程 访问 
Hashtable 时 ， 不 需要 开发 人 员 对 它 进行 同步 ， 而 对 于 HashMap， 开 发 人 员 必 须 提 供 额 外 的 同 
步 机制 。 所 以 ， 效 率 上 HashMap 可 能 高 于 Hashtable。 

4)“ 快 速 失 败 ” 也 就 是 fail-fast， 它 是 Java 集合 的 一 种 错误 检测 机 制 。 当 多 个 线程 对 集合 
进行 结构 上 的 改变 的 操作 时 ， 就 有 可 能 会 产生 fail-fast 事件 。 例如， 假设 存在 两 个 线程 ， 它 们 
分 别 是 线程 1 与 线程 2， 当 线程 1 通过 Iterator (迭代 器 ) 在 遍历 集合 A 中 的 元 素 的 时 候 ， 如 
果 线 程 2 修改 了 集合 A 的 结构 《删除 或 增加 新 的 元 素 )， 那 么 ， 这 个 时 候 程序 就 会 抛 出 
ConcurrentModificationException 异常 ， 从 而 产生 fail-fast 事件 。 
于 Hashtable 是 线程 安全 的 , 因此 , 没有 采用 快速 失败 机 制 , HashMap 是 非 线程 安全 的 ， 
因此 ， 友 代 HashMap 采用 了 快速 失败 机 制 。 

从 以 上 分 析 可 知 ， 选 项 A、 选 项 C 与 选项 DD 的 描述 都 是 正确 的 ， 只 有 选项 B 的 描述 不 正 
确 ， 因 为 Hashtable 不 允许 键 值 为 null。 
所 以 ， 本 题 的 答案 为 A、C、D。 

18. 答案 : A。 

分 析 : 本题 考察 的 是 List 迭代 器 Iterator 的 知识 。 

Iterator 支持 从 源 集合 中 安全 地 删除 对 象 ， 删 除 的 方法 为 在 Iterator 上 调用 remove0 方 法 。 
这 样 做 的 好 处 是 可 以 避免 ConcurrentModifiedException 异常 发 生 ， 当 打开 Iterator 迭代 集合 
时 ， 同 时 又 在 对 集合 进行 修改 。 有 些 集 合 不 允许 在 迭代 时 删除 或 添加 元 素 ， 但 是 调用 Iterator 
的 remove0 方法 是 个 安全 的 做 法 。 

remove() 方 法 的 作用 为 从 进 代 器 指向 的 集合 中 移 除 欠 代 器 返回 的 最 后 一 个 元 素 〈 可 选 
操作 )， 每 次 调用 next(0 方 法 只 能 调用 一 次 此 方法 。 如 果 在 进行 迭代 时 ， 用 调用 此 方法 之 
外 的 其 他 方式 修改 了 该 欠 代 器 所 指向 的 集合 ， 那 么 友 代 器 的 行为 是 不 明确 的 。 因 此 ， 选 
项 A 正确 。 
所 以 ， 本 题 的 答案 为 A。 

19. 答案 : A、B、C。 

分 析 : 本 题 考察 的 是 算法 基础 知识 。 

算法 指 的 是 解 题 方案 的 准确 而 完整 的 描述 ， 是 一 系列 解决 问题 的 清晰 指令 ， 算 法 代表 着 
用 系统 的 方法 描述 解决 问题 的 策略 机 制 。 其 主要 功能 是 对 输入 结果 特定 的 运算 产生 期 望 的 输 
出 ， 所 以 ， 输 入 数据 、 处 理 数据 及 输出 结果 都 属于 算法 结构 ， 显 然 ， 存 储 数据 的 功能 的 并 不 
包括 在 内 。 所 以 ， 选 项 A、 选 项 B 和 选项 C 正确 。 

所 以 ， 本 题 的 答案 为 A、B、C。 

20. 答案 : D。 

分 析 : 本 题 考 察 的 是 对 二 又 树 各 种 遍历 知识 的 理解 。 

要 想 找 出 本 题 的 正确 答案 ， 首 先 要 弄 明 白 二 又 树 的 几 种 遍历 方式 的 原理 。 

后 序 遍 历 : 首先 遍历 左 子 树 ， 然 后 遍历 右 子 树 ， 最 后 访问 根 结 点 ， 在 遍历 左 、 右 子 树 时 ， 
仍然 先 遍历 左 子 树 ， 然 后 遍历 右 子 树 ， 最 后 遍历 根 结 点 。 

中 序 遍 历 : 首先 遍历 左 子 树 ， 然 后 访问 根 结 点 ， 最 后 凯 历 右 子 树 。 在 遍历 左 、 右 子 树 时 ， 
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仍然 先 遍 历 左 子 树 ， 再 访问 根 结 点 ， 最 后 遍历 右 子 树 。 

前 序 遍 历 : 首先 访问 根 结 点 然后 遍历 左 子 树 ， 最 后 遍历 右 子 树 。 在 遍历 左 、 右 子 树 时 ， 
仍然 先 访问 根 结 点 ， 然 后 遍历 左 子 树 ， 最 后 遍历 右 子 树 。 
本 题 中 ， 由 后 序 遍 历 序列 为 dabec 可 知 ， 根 结 点 为 c， 再 通过 中 序 遍 历 序列 可 知 ， 右 子 树 
为 空 。 接 着 由 dabe 可 知 ， 其 根 结 点 为 e 所 以 ， 在 中 序 裔 历 序列 deba 中 ， 左 子 树 为 4， 右 子 
树 为 ba。 后 序 遍 历 序列 为 ab， 中 序 遍 历 序列 为 ba， 可 以 推断 出 b 为 根 结 点 (相对 于 a 而 言 )， 
a 为 右 子 树 。 所 以 ， 可 以 得 到 前 序 遍 历 序列 为 cedba。 所 以 ， 选 项 B 正确 。 

所 以 ， 本 题 的 答案 为 了 B。 

21. 答案 : D。 

分 析 : 本 题 考 察 的 是 算法 的 空间 复杂 度 知 识 。 

空间 复杂 度 是 对 一 个 算法 在 运行 过 程 中 临时 占用 存储 空间 大 小 的 量度 。 算 法 在 运行 时 占 
用 的 临时 空间 与 算法 的 长 度 、 程 序 的 指令 条 数 以 及 程序 所 占用 的 存储 空间 都 没有 直接 关系 。 
显然 ， 与 此 符合 的 描述 只 有 选项 D。 所 以 ， 选 项 D 正确 。 

所 以 ， 本 题 的 答案 为 D。 

22. 答案 : D。 

分 析 : 本 题 考 察 的 是 二 又 树 的 知识 。 

二 又 树 是 非 线性 数据 结构 ， 即 每 个 数据 结 点 至 多 只 有 一 个 前 驱 ， 但 可 以 有 多 个 后 继 ， 可 
以 使 用 顺序 存储 和 链 式 存储 两 种 结构 来 存储 。 以 下 将 分 别 对 这 两 种 存储 结构 进行 介绍 。 

(1) 顺序 存储 结构 

二 义 树 的 顺序 存储 指 的 是 用 元 素 在 数组 中 的 下 标 表 示 一 个 结 点 与 其 孩子 和 父 结 点 的 关 
系 。 这 种 结构 特别 适用 于 近似 满 二 又 树 。 这 种 方法 的 缺点 是 可 能 会 有 大 量 空间 的 浪费 ， 在 最 
坏 的 情况 下 ， 一 个 深度 为 k 且 只 有 k 个 结 点 的 右 单 支 树 需要 2^k-1 个 结 点 存储 空间 。 如 图 6 
所 示 分 别 给 出 了 完全 二 又 树 和 非 完 全 二 又 树 的 存储 示意 图 。 


ss 3 


与 


全 四 园 中 回国 加 加 
3 对 和 


上 斧 


图 6 二 又 树 的 顺序 存储 方式 
a) 完全 二 又 树 的 存储 方式 b) 非 完 全 二 又 树 的 存储 方式 
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(2) 链 式 存储 结构 
二 叉 树 的 链 式 存储 结构 是 指 用 链表 来 表示 一 棵 二 又 树 。 
每 个 结 点 有 一 个 数据 域 ， 两 个 指针 域 分 别 指向 左 孩子 和 右 孩 子 。 其 结 点 结构 为 


如 图 7 所 示 给 出 了 一 个 二 又 树 的 链表 存储 方式 。 


图 7 二 又 树 的 链表 存储 方式 


通过 上 面 的 分 析 可 知 ， 选 项 D 正确 。 

所 以 ， 本 题 的 答案 为 D。 

23. 答案 : A。 

分 析 : 本 题 考 察 的 是 二 又 树 的 知识 。 

二 义 树 具有 以 下 性 质 ， 一 棵 非 空 二 又 树 的 第 i 层 上 最 多 有 2^(i-1) 个 结 点 (i 宇 1)。 所 以 ， 
本 题 中 ， 第 4 层 的 结 点 数 最 多 为 2^*3=8。 所 以 ， 选 项 A 正确 。 

所 以 ， 本 题 的 答案 为 A。 

24. 答案 : C。 

分 析 : 本 题 考察 的 是 对 快速 排序 算法 的 理解 。 

快速 排序 是 一 种 非常 高 效 的 排序 算法 ， 它 采用 “分 而 治之 ”的 思想 ， 把 大 的 拆 分 为 小 的 ， 
小 的 再 拆 分 为 更 小 的 。 其 原理 如 下 : 对 于 一 组 给 定 的 记录 ， 通 过 一 趟 排序 后 ， 将 原 序列 分 为 
两 部 分 ， 其 中 前 一 部 分 的 所 有 记录 均 比 后 一 部 分 的 所 有 记录 小 ， 然 后 再 依次 对 前 后 两 部 分 的 
记录 进行 快速 排序 ， 递 归 该 过 程 ， 直 到 序列 中 的 所 有 记录 均 有 序 为 止 。 

一 趟 快速 排序 的 算法 步骤 如 下 : 

1) 设置 两 个 变量 i、j， 排 序 开始 的 时 候 : 二 0，jF=N-1。 

2) 以 第 一 个 数组 元 素 作 为 关键 数据 ， 赋 值 给 key， 即 key=A[0]。 

3) 从 j 开始 向 前 搜索 ， 即 逆向 遍历 数组 G--)， 找 到 第 一 个 小 于 key 的 值 Aj]， 将 A 中 和 


A 四 互 换 。 
4) 从 i 开始 向 后 搜索 , 即 正 向 遍历 数组 (i++)， 找 到 第 一 个 大 于 key 的 A 自 , 将 A 中 和 ADj] 
互 换 。 


5) 重复 第 3)、4) 步 ， 直 到 i=j。 
对 于 本 题 而 言 , 把 5 作为 基准 , 执行 过 程 如 下 : 首先 ， 从 数组 最 右边 开始 遍历 ， 由 于 8>5， 
因此 ， 不 需要 移动 8 的 位 置 ， 接 着 向 后 遍历 数组 元 素 3， 由 于 3<5， 因 此 ， 交 换 这 两 个 数组 元 
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素 的 值 ， 此 时 数组 中 的 元 素 为 3，2，6，5，8)， 接 着 正 向 遍历 数组 ， 下 一 个 遍历 的 值 为 2， 
不 需要 移动 2 的 位 置 ， 接 着 遍历 6， 由 于 6>5， 因 此 ， 需 要 交换 5 和 6 的 位 


趟 快速 排序 结 


由 于 2<$， 因 


可 


~ 


此 ， 
此 时 数组 的 值 为 


梧 试 笔试 真题 尼 


束 。 


所 以 ， 选 项 C 正确 。 


3，2，5，6，8)， 此 时 已 经 遍历 了 数组 中 所 有 的 值 ， 


所 以 ， 本 题 的 答案 为 C。 
25. 答案 : C。 
分 析 : 本 题 考 察 的 是 数据 库 的 相关 知识 。 


对 于 选项 A，Hibernate 


是 一 个 开放 源 代 码 的 对 象 关系 映射 框架 ， 它 对 JDBC 进行 了 非常 


轻 量 级 的 对 象 封装 , 使 得 Java 程序 员 可 以 随心 所 和 欲 地 使 用 对 象 编程 思维 来 操纵 数据 库 。 所 以 ， 


选项 A 不 正确 。 


对 于 选项 B，Java 应 


] 程 


序 可 以 通过 JDBC 或 Hibernate 对 数据 库 系 统 进行 访问 。 虽 


然 JDBC 和 Hibernate 都 提供 了 事务 控制 的 接口 , 但 这 些 接口 上 只是 把 事务 控制 相关 的 命令 发 送 
给 数据 库 系 统 ， 由 数据 库 系 统 来 控制 事务 的 隔离 级 别 。 所 以 ， 选 项 B 不 正确 。 


对 于 选项 C， 数 据 库 系统 是 为 适应 数据 处 理 的 需要 而 发 展 起 来 的 一 种 较为 理 
理 系 统 ， 也 是 一 个 为 实际 可 运行 的 存储 、 维 护 和 应 用 系统 提供 数据 的 软件 系统 ， 是 存储 介 


处 理 对 象 和 管理 
提出 了 事务 隔离 级 别 。 在 标准 SQL 规范 


上 人 一 


L 


的 集合 体 。 在 数据 库 操 作 中 ， 为 了 保证 在 3 


发 情况 下 数据 读 写 的 正 丰 
Fh， 定 义 了 4 个 事务 隔离 级 别 ， 分 别 为 未 授权 读 取 ， 


想 的 数据 处 
质 、 


性 ， 


也 称 为 读 未 提交 (read uncommitted); 授权 读 取 ， 也 称 为 读 提 交 (read committed); 可 重复 读 
取 (repeatable read); 序列 化 (serializable )。 因 此 ， 事 务 隔离 级 别 是 由 数据 库 系 统 实现 的 。 所 


以 ， 选 项 C 1] 


对 于 选项 D，JDBC 纪 
据 库 提供 统一 访问 。 所 以 ， 选 项 DD 不 正确 。 


F 确 。 


所 以 ， 本 题 的 答案 为 C。 
26. 答案 : B。 


分 析 : 本 题 考 察 的 是 对 双向 链表 知识 的 理解 
项 A， 最 后 一 个 操作 p->right->left=s， 


对 于 选 ] 


于 s->left=s, 


对 于 选项 B， 描 述 正确 。 
对 于 选项 C， 如 果 先 执行 语句 p->right=s， 由 于 没有 记录 结 点 p 的 后 继 结 点 
的 操作 将 无 法 找到 结 点 p 的 后 继 结 点 。 因 
对 于 选项 D，p->right->left=s 也 等 价 于 s->left=s， 显 然 是 错误 的 。 


显然 是 错误 的 。 因 此 ， 选 项 A 错误 。 


因此 ， 选 项 B 正确 。 


此 ， 选 项 C 错误 。 


所 以 ， 本 题 的 答案 为 B。 
27. 答案 : C。 


分 析 : 本 题 考察 对 常见 排序 算法 原理 的 理解 。 


对 于 选项 A， 归 并 排序 是 利 


递归 与 分 治 


再 对 子 序 列 排 序 ， 最 后 再 


3 


K 动 程序 是 一 种 用 于 执行 SQL 语句 的 Java API， 可 以 为 多 种 关系 数 


此 时 ，p->right 指向 s，p->right->left=s 等 价 


因此 ， 后 面 


因此 ， 选 项 D 错误 。 


技术 将 数据 序列 划分 成 为 越 来 越 小 的 子 序列 ， 
j 递 归 方 法 将 排 好 序 的 子 序列 合并 成 为 越 来 越 大 的 有 序 序列 。 


对 于 选项 B， 和 希 尔 排序 也 称 为 “缩小 增 量 排序 ” 其 基本 原理 如 下 首先 将 待 排序 的 数组 
元 素 分 成 多 个 子 序列 ， 使 得 每 个 子 序列 的 元 素 个 数 相对 较 少 ， 然 后 对 各 个 子 序列 分 别 进 行 直 
符 排 序 序列 “基本 有 序 后 ” 最 后 再 对 所 有 元 素 进行 一 次 直接 插入 排序 。 


接 插入 排序 ， 
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对 于 选项 C， 插 入 排序 是 指 对 于 给 定 的 一 组 记录 ， 初 始 时 假设 第 一 个 记录 自 成 一 个 有 序 
序列 ， 其 余 的 记录 为 无 序 序列 。 接 着 从 第 二 个 记录 开始 ， 按 照 记 录 的 大 小 依次 将 当前 处 理 的 
记录 插入 到 其 之 前 的 有 序 序列 中 ， 直 至 最 后 一 个 记录 插入 到 有 序 序列 中 为 止 。 

对 于 选项 D， 选 择 排序 是 一 种 简单 直观 的 排序 算法 ， 它 的 基本 原理 如 下 : 对 于 给 定 的 一 
组 记录 ， 经 过 第 一 轮 比较 后 得 到 最 小 的 记录 ， 然 后 将 该 记录 与 第 一 个 记录 的 位 置 进行 交换 ; 
接着 对 不 包括 第 一 个 记录 以 外 的 其 他 记录 进行 第 二 轮 比较 ， 得 到 最 小 的 记录 并 与 第 二 个 记录 
进行 位 置 交 换 ， 重 复 该 过 程 ， 直 到 进行 比较 的 记录 只 有 一 个 时 为 止 。 

从 以 上 分 析 可 以 看 出 ， 题 目 所 描述 的 排序 方法 为 插入 排序 。 所 以 ， 选 项 C 正确 。 

所 以 ， 本 题 的 答案 为 C。 

28. 答案 : A、B。 

分 析 : 本 题 考 察 的 是 操作 系统 的 知识 。 

操作 系统 (Operating System，OS ) 是 一 个 庞大 的 管理 控制 程序 ， 管 理 计 算 机 硬件 与 软件 
资源 ， 同 时 ， 它 也 是 计算 机 系统 的 内 核 与 基石 ， 大 致 包括 5 个 方面 的 管理 功能 : 进程 与 处 理 
机 管理 、 作 业 管理 、 存 储 管理 、 设 备 管 理 及 文件 管理 。 
通过 上 面 的 分 析 可 知 ， 选 项 A 与 选项 B 正确 。 
所 以 ， 本 题 的 答案 为 A、B。 

29. 答案 A、B、D。 

分 析 : 本 题 考 察 的 是 中 断 的 基础 知识 。 

中 断 源 一 般 可 分 为 两 类 : 强迫 性 中 断 和 自愿 性 中 断 。 强 迫 性 中 断 由 随机 事件 引起 而 非 程 
序 员 事先 安排 ， 它 包括 输入 /输出 中 断 、 硬 件 故 障 中 断 、 时 钟 中 断 、 控 制 台中 断 和 程序 性 中 断 。 
设备 出 错 、 执 行 print 语句 属于 其 中 的 输入 /输出 中 断 ; 断 电 属 于 硬件 故障 中 断 。 时 间 片 到 时 属 
于 自愿 性 中 断 。 

所 以 ， 选 项 A、 选 项 B 和 选项 D 正确 。 

所 以 ， 本 题 的 答案 为 A、B、D。 

30. 答案 : A。 

分 析 : 本 题 考 察 的 是 操作 系统 基础 知识 。 

进程 的 基本 调度 状态 有 运行 、 就 绪 和 阻塞 。 进 程 调 度 程 序 从 处 于 就 绪 状 态 的 进程 中 选择 
一 个 投入 和 运行。 运行 进程 因 等 待 某 一 事件 而 进入 阻塞 状态 ， 因 时 间 片 到 达 而 回 到 就 绪 状 态 。 
处 于 阻塞 状态 的 进程 当 所 等 待 的 事件 发 生 时 ， 便 进入 就 绪 状 态 。 

本 题 中 ， 就 绪 队 列 是 等 待 CPU 时 间 的 队列 ， 其 中 存放 着 等 待 执行 的 任务 。 进 程 调度 是 从 
就 绪 队 列 中 选择 一 个 进程 投入 运行 。 所 以 ， 选 项 A 正确 。 

所 以 ， 本 题 的 答案 为 A。 

31. 答案 : D。 

分 析 : 本 题 考 察 的 是 对 死 锁 基础 知识 的 理解 。 

所 谓 死 锁 是 指 两 个 或 两 个 以 上 的 进程 在 执行 过 程 中 ， 由 于 党争 资源 或 者 彼此 通信 而 造成 
的 一 种 阻塞 的 现象 ， 若 无 外 力作 用 ， 它 们 都 将 无 法 推进 下 去 。 此 时 称 系统 处 于 死 锁 状 态 或 系 
统 产 生 了 死 锁 ， 这 些 永远 在 互相 等 待 的 进程 称 为 死 锁 进 程 。 举 一 个 简单 的 例子 : 在 吃饭 的 时 
候 ， 只 有 拿 到 一 双 筷 子 后 才能 开始 吃饭 ， 如 果 有 两 个 人 ， 每 个 人 都 上 只 拿 了 一 根 饶 子 ， 而 等 待 
男 一 根 秒 子 可 用 的 时 候 ， 就 拿 过 来 开始 吃饭 ， 此 时 ， 两 个 人 都 已 经 占用 了 部 分 资源 (一 根 特 
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子 )， 而 等 待 男 一 个 资源 ( 另 一 根 秘 子 )， 此 时 两 个 人 永远 都 在 等 待 对 方 释放 资源 ， 因 此 ， 
生 了 和 死 锁 。 可 以 通过 外 力作 用 把 一 个 人 的 筷子 强制 释放 掉 而 给 另外 一 个 人 而 解决 死 锁 。 很 
然 ， 选 项 D 的 描述 符合 死 锁 的 定义 。 

所 以 ， 本 题 的 答案 为 D。 

32. 答案 : B。 

分 析 : 本 题 考察 的 是 死 锁 知 i 

本 题 中 ， 不 发 生死 锁 的 条 件 是 至 少 能 保证 1 个 进程 获得 3 台 打印 机 资源 。 最 坏 的 情况 是 
1 个 进程 获取 了 3 台 打 印 机 资源 ， 另 外 N-1 个 进程 获取 到 2 台 打 印 机 ， 等 待 获取 第 3 台 。 

所 以 ， 本 题 可 以 构建 如 下 等 式 关 系 : 3+(N-1)*2=11， 解 算 结果 为 N=5。 所 以 ， 选 项 B 
正确 。 

所 以 ， 本 题 的 答案 为 了 B。 

33. 答案 ，A。 

分 析 : 本 题 考察 的 是 计算 机 网 络 与 通信 知识 。 

JP 《Internet Protocol， 网 络 之 间 互 联 的 协议 ， 简 称 为 “网 协 ”) 是 为 计算 机 网 络 相互 连 接 
进行 通信 而 设计 的 协议 。 在 因特网 中 ， 它 是 能 使 连接 到 网 上 的 所 有 计算 机 网 络 实现 相互 通信 
的 一 套 规则 ， 规 定 了 计算 机 在 因特网 上 进行 通信 时 应 当 遵 守 的 规则 。 

IP 协议 定义 在 OSLRM (Open System Interconnect/Reference Model， 开 放 式 系统 互联 参考 
模型 ) 的 第 三 层 即 网 络 层 ， 在 卫 协议 中 ， 规 定 了 在 Internet 上 进行 通信 时 应 遵守 的 规则 ， 例 
如 IP 数据 包 的 组 成 、 路 由 器 如 何 将 卫 数据 包 送 到 目的 主机 等 。 所以， 选项 A 正确 。 

对 于 选项 B， 处 于 应 用 层 中 的 协议 有 HTTP、FTP、SMTP 和 POP3 等 。 所 以 ， 选 项 B 不 
正确 。 

对 于 选项 C， 处 于 数据 链 路 层 中 的 协议 有 PPP、ARP 及 RARP 等 。 所以， 选项 C 不 正确 。 

对 于 选项 D， 处 于 传输 层 中 的 协议 有 TCP、UDP 等 。 所 以 ， 选 项 D 不 正确 。 

所 以 ， 本 题 的 答案 为 A。 

34. 答案 : D。 

分 析 : 本 题 考 察 的 是 计算 机 网 络 与 通信 知识 。 

对 于 选项 A，IP 协议 主要 关心 的 是 如 何 将 数据 从 一 个 设备 经 过 一 个 互联 网 络 发 送 到 另 一 
个 设备 。 所 以 ， 选 项 A 不 正确 。 

对 于 选项 B, ICMP 是 互联 网 控制 报 文 协议 , 卫 通过 ICMP 来 交换 错误 信息 或 者 其 他 重要 
信息 ， 它 工作 在 网 络 层 。 所 以 ， 选 项 B 不 正确 。 

对 于 选项 C，ARP (Address Resolution Protocol， 地 址 解析 协议 ) 是 根据 IP 地 址 获取 物理 
地 址 的 一 个 TCP/IP 协议 。 主 机 发 送信 息 时 将 包含 目标 IP 地 址 的 ARP 请 求 广播 到 网 络 上 的 所 
有 主机 ， 并 接收 返回 消息 ， 以 此 确定 目标 的 物理 地 址 ， 收 到 返回 消息 后 将 该 IP 地 址 和 物理 地 
址 存 入 本 机 ARP 缓存 中 并 保留 一 定时 间 ， 下 次 请 求 时 直接 查询 ARP 缓存 以 节约 资源 。 所 以 ， 
选项 C 不 正确 。 

对 于 选项 D，RARP (Reverse Address Resolution Protocol， 反 向 地 址 解析 协议 ) 与 ARP 
相反 。RARP 发 出 要 反 向 解析 的 物理 地 址 ， 并 希望 返回 其 对 应 的 卫 地 址 ， 应 答 包括 由 能 够 提 
供 所 需 信 息 的 RARP 服务 器 发 出 的 全 地 址 。 虽 然 发 送 方 发 出 的 是 广播 信息 ，RARP 规定 只 有 
RARP 服务 器 能 产生 应 答 。 许 多 网 络 指定 了 多 个 RARP 服务 器 ， 这 样 做 既是 为 了 平衡 负载 ， 


后 范 
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也 是 为 了 作为 出 现 问题 时 的 备份 。 所 以 ， 选 项 D 正确 。 

所 以 ， 本 题 的 答案 为 D。 

35. 答案 : B。 

分 析 : 本 题 考 察 的 是 计算 机 网 络 与 通信 的 基础 知识 。 

本 题 中 ，130.63.160.2 是 B 类 耳 地 址 ,而 B 类 卫 地 址 的 前 16 位 (两 个 字 节 ) 为 网 络 号 ， 
后 16 位 是 主机 和 号， 划分 子 网 就 是 将 主机 号 中 的 一 部 分 拿 出 来 当 作 子 网 号 ， 本 题 中 ， 子 网 掩 码 
为 255.255.255.0， 也 就 是 把 前 三 个 学 季 当 成 了 网 络 写 。 

与 B 类 TP 地 址 默认 的 前 两 个 字 节 作为 网 络 号 相 比 ， 第 三 个 字 节 就 是 子 网 号 ， 即 160， 所 
以 ， 这 个 人 PP 的 网 络 号 是 130.63， 子 网 号 为 160， 主 机 号 是 2。 所 以 ， 选 项 B 正确 。 

所 以 ， 本 题 的 答案 为 了 B。 

36. 答案 : C。 

分 析 : 本 题 考 察 的 是 计算 机 网 络 与 通信 的 知识 。 

IP 地 址 根据 网 络 ID 的 不 同 分 为 $ 种 类 型 : A 类 地 址 、B 类 地 址 、C 类 地 址 、D 类 地 址 和 
E 类 地 址 。 

(1) A 类 IP 地 址 

一 个 A 类 人 Pp 地 址 由 1 字 节 的 网 络 地 址 和 3 字 节 主机 地 址 组 成 , 网 络 地 址 的 最 高 位 必须 是 
“0” 地 址 范围 为 1.0.0.0 一 126.0.0.0。 可 用 的 A 类 网 络 有 126 个 ， 每 个 网 络 能 容纳 1 亿 多 个 
主机 。 

(2) B 类 耳 地 址 

一 个 B 类 了 下 地 址 由 2 个 字 节 的 网 络 地 址 和 2 个 字 节 的 主机 地 址 组 成 , 网 络 地 址 的 最 高 位 
必须 是 “10” 地 址 范围 为 128.0.0.0 一 191.255.255.255。 可 用 的 B 类 网 络 有 16382 个 ， 每 个 网 
络 能 容纳 6 万 多 个 主机 。 

(3)C 类 了 P 地 址 

一 个 C 类 IP 地 址 由 3 字 节 的 网 络 地 址 和 1 字 节 的 主机 地 址 组 成 , 网 络 地 址 的 最 高 位 必须 
是 “110”。 地 址 范围 为 192.0.0.0~223.255.255.255。C 类 网 络 可 达 209 万 余 个 ， 每 个 网 络 能 容 
纳 254 个 主机 。 

(4) DD 类 IP 地 址 

D 类 TP 地 址 的 第 一 个 字 节 以 “1110” 开 始 ， 它 是 一 个 专门 保留 的 地 址 。 它 并 不 指向 特定 
的 网 络 ， 目 前 这 一 类 地 址 被 用 在 多 点 广播 (Multicast) 中 。 多 点 广播 地 址 用 来 一 次 寻 址 一 组 计 
算 机 ， 它 标识 共享 同一 协议 的 一 组 计算 机 。 

(5) EE 类 IP 地址 

EE 类 IP 地址 的 第 一 个 字 节 以 “11110” 开 始 ， 为 将 来 使 用 保留 。 

通过 上 面 分 析 可 知 ，200.5.6.4 属于 192.0.0.0 一 223.255.255.255 范围 内 ， 属 于 C 类 地 址 范 
畴 。 所 以 ， 选 项 C 正确 。 

所 以 ， 本 题 的 答案 为 C。 

37. 答案 : B。 

分 析 : 本 题 考 察 的 是 计算 机 网 络 与 通信 的 基础 知识 。 

网 关 是 局 域 网 连接 广域网 的 出 口 ， 可 以 工作 在 OSI 模型 网 络 层 以 上 的 不 同 层次 。 所 以 ， 
选项 B 正确 。 
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所 以 ， 本 题 的 答案 为 也 。 

三 、 问 答题 

1. 答案 : <? extends T> 表 示 类 型 的 上 界 ， 也 就 是 说 ,参数 化 的 类 型 可 能 是 T 或 者 工 的 子 
。 例 如 ， 下 面 的 写法 都 是 合法 的 赋值 语句 : 


并 


List<?extends Number> list = new ArrayList<Number>(); 
List<? Extends Number> list = new ArrayList<Integer>(); // Integer 是 Number 的 子 类 
List<? Extends Number> list = new ArrayList<Float>0; /Float 也 是 Number 的 子 类 


<? extends T> 被 设计 为 用 来 读数 据 的 泛 型 (只 能 读 取 类 型 为 T 的 元 素 )， 原 因 如 下 : 

(1) 在 上 面 赋值 的 示例 中 ， 对 读数 据 进 行 分 析 

1) 不 管 给 list 如 何 赋 值 ， 可 以 保证 list 里 面 存放 的 一 定 是 Number 类 型 
可 以 从 list 列表 里 面 读 取 Number 类 型 的 值 。 

2) 不 能 从 list 中 读 取 Integer， 因 为 list 里 面 可 能 存放 的 是 Float 值 , 同 理 , 也 不 可 以 从 list 
里 面 读 取 Float。 

(2) 对 写 数据 进行 分 析 

1) 不 能 向 list 中 写 Number， 因 为 list 中 有 可 能 存放 的 是 Float。 

2) 不 能 向 list 中 写 Integer， 因 为 list 中 有 可 能 存放 的 是 Float。 

3) 不 能 向 list 中 写 Float， 因 为 list 中 有 可 能 存放 的 是 Integer。 

从 上 面 的 分 析 可 以 发 现 ,只 能 从 List<? extends T> 读 取 T， 因 为 无 法 确定 它 实际 指 向 列表 
的 类 型 ， 从 而 无 法 确定 列表 里 面 存放 的 实际 的 类 型 ， 所 以 ， 无 法 向 列表 里 面 添加 元 素 。 


<? super T> 表 示 类 型 下 界 ， 也 就 是 说 ， 参 数 化 的 类 型 是 此 类 型 的 超 类 型 〈 父 类 型 )。 


或 其 子 类 ， 因 此 ， 


民 


List<?super Float>list = new ArrayList<Float>() 
List<?super Float>list = new ArrayList<Number>(); /Number 是 Float 的 父 类 
List<?super Float>list = new ArrayList<Object>0; /Object 是 Number 的 父 类 


<? super IT 被 设计 为 用 来 写 数据 的 泛 型 〈 只 能 写 入 工 或 工 的 子 类 类 型 )， 不 能 用 来 读 ， 分 
析 如 下 : 

(1) 读数 据 

无 法 保证 list 里 面 一 定 存放 的 是 Float 类 型 或 Number 类 型 ， 因 为 有 可 能 存放 的 是 Object 
类 型 ， 唯 一 能 确定 的 是 list 里 面 存 放 的 是 Object 或 其 子 类 ， 但 是 无 法 确定 具体 子 类 的 类 型 。 
正 是 由 于 无 法 确定 list 里 面 存 放 数 据 的 类 型 ， 因 此 ， 无 法 从 list 里 面 读 取 数 据 。 

(2) 写 数 据 

1) 可 以 向 list 里面 写 入 Float 类 型 的 数据 (不 管 list 里 面 实际 存放 的 是 Float、Number 或 
者 Object， 写 入 Float 都 是 允许 的 )， 同 理 ， 也 可 以 向 list 里 面 添加 Float 子 类 类 型 的 元 素 。 

2) 不 可 以 向 list 里 面 添加 Number 或 Object 类 型 的 数据 ， 因 为 list 中 可 能 存放 的 是 Float 
类 型 的 数据 。 

下 面 给 出 两 个 泛 型 使 用 的 场景 : 


public class Collections 


{ 


public static <T> void copy(List<? super T> dest, List<? extends T> src) 
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for (int 1=0; i<src.size(); i++) 


dest.set(l,Src.get(i)); 


} 


2. 答案 : 两 种 单 例 模式 的 实现 代码 如 下 所 示 : 


public class Test 
{ 
private static Test test = new Test(); 
public TestO{ } 
public static Test getInstance() 
{ 
return test; 
} 
} 
与 小 二 
public class Test 
{ 
private static Test test = null; 
private Test(){  } 
public static Test getInstance() 
{ 
if (test == null) 
{ 
test = new Test(); 
} 
return test; 
} 
} 


对 于 第 一 种 写法 ， 当 类 被 加 载 的 时 候 ， 已 经 创建 好 了 一 个 静态 的 对 象 ， 因 此 ， 是 线程 安 
全 的 ， 但 缺点 是 在 这 个 对 象 还 没有 被 使 用 的 时 候 就 已 经 被 创建 出 来 了 。 

对 于 第 二 种 写法 ， 缺 点 如 下 : 这 种 写法 不 是 线程 安全 的 ， 例 如 当 第 一 个 线程 执行 判断 语 
句 iftest==nul) 时 ， 第 二 个 线程 执行 判断 语句 ifltest==null))， 接 着 第 一 个 线程 执行 语句 
test = new Test()， 第 二 个 线程 也 执行 语句 test = new Test0， 在 这 种 多 线程 环境 下 ， 可 能 会 创建 出 
两 个 对 象 。 当 然 ， 这 种 写法 的 优点 是 按 需 创 建 对 象 ， 只 有 对 象 被 使 用 的 时 候 才 会 被 创建 。 

3. 答案 : 接口 是 一 种 特殊 形式 的 抽象 类 , 使 用 接口 完全 有 可 能 实现 与 抽象 类 相同 的 操作 ， 
但 一 般 而 言 ， 抽 和 象 类 多 用 于 在 同类 事物 中 有 无 法 具体 描述 的 方法 的 场景 ， 所 以 ， 当 子 类 和 父 
类 之 间 存 在 有 逻辑 上 的 层次 结构 时 ， 推 荐 使 用 抽象 类 ， 而 接口 多 用 于 不 同类 之 间 ， 定 义 不 同 
类 之 间 的 通信 规则 ， 所 以 ， 当 希望 支持 差别 较 大 的 两 个 或 者 更 多 对 象 之 间 的 特定 交互 行为 时 ， 
应 该 使 用 接口 。 使 用 接口 能 大 大 降低 软件 系统 的 耦合 度 。 
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4. 答案 : int 和 Integer 的 区 别 如 下 : 

1) int 是 Java 语言 提供 的 8 种 基本 的 原始 数据 类 型 之 一 ， 当 作为 对 象 的 属性 的 时 候 ， 它 
的 默认 值 为 0。 而 Integer 是 Java 为 int 提供 的 封装 类 ， 默 认 值 为 null。 由 此 可 见 ，int 无 法 区 
分 未 赋值 与 赋值 为 0 的 情况 ， 而 Integer 却 可 以 区 分 这 两 种 情况 。 

2) int 是 基本 类 型 ， 在 使 用 的 时 候 是 值 传递 ， 而 Integer 是 引用 。 

3) int 只 能 用 来 运算 ， 而 Integer 可 以 做 更 多 的 事情 ， 因 为 Integer 提供 了 很 多 有 用 的 方法 。 

4) 当 需 要 往 容 器 (例如 List) 里 存放 整数 时 ， 无 法 直接 存放 int， 因 为 List 里 面 放 的 都 是 
对 象 ， 所 以 在 这 种 情况 下 只 能 使 用 Integer。 

5. 答案 : 本 题 可 以 采用 递归 法 与 非 递 归 法 两 种 方法 实现 。 以 下 将 分 别 对 这 两 种 方法 进行 
分 析 。 
具体 步骤 如 下 所 示 : 

1) 比较 链表 1 (head1) 和 链表 2 (head2 ) 的 第 一 个 结 点 数据 ， 如 果 head1.data<head2.data， 
则 把 结果 链表 头 结 点 指向 链表 headl 中 的 第 一 个 结 点 。 

2) 对 剩余 的 链表 head1.next 和 链表 2 (head2) 再 调用 同样 的 方法 ， 比 较 得 到 结果 链表 的 
第 二 个 结 点 ， 添 加 到 合并 后 列表 的 后 面 。 

3) 一 直 递 归 调 用 步骤 2)， 直 到 两 个 链表 的 结 点 都 被 加 到 结果 链表 中 。 

实现 代码 如 下 所 示 : 


class Node 
{ 
Node next = null; 
int data; 
public Node(int data) 
{ 
this.data = data; 
} 
} 
public class Test 
{ 


public static Node mergeList(Node head1, Node head2) 
{ 
if (head1 == null) 
return head2; 
if (head2 == null) 
return head1l; 
Node head = null; 
if (headl1.data < head2.data) 


{ 

head = head!1; 

head.next = mergeList(head1.next, head2); 
} 
else 
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head = head2; 
head.next = mergeList(head1, head2.next); 


} 


return head; 


public static void main(String[ | args) 
{ 
Node headl=new Node(]); 
Node node3=new Node(3); 
head1.next=node3; 
Node nodeS=new Node(5); 
node3.next=node5; 
nodeS.next=null; 


Node head2=new Node(2); 
Node node4=new Node(4); 
head2.next=node4; 

Node node6=new Node(6); 
node4.next=node0; 
node6.next=null; 


Node mergeHead=mergeList(head1,head2); 
while(mergeHead!=null) 


{ 


System.out.print(mergeHead.datat" "); 
mergeHead=mergeHead.next; 


} 


[rt 


星 序 的 运行 结果 为 


123456 


I 


方法 二 : 非 递 归 法 


在 遍历 两 个 链表 的 过 程 中 ， 改 变 当 前 链表 指针 的 指向 来 把 两 个 链表 串联 成 
表 ， 实 现代 码 如 下 : 


个 有 序 的 列 


public static Node mergeList(Node head1, Node head2) 
| 
这 (headl == null) 
return head2; 
if (head2 == null) 
return head!l; 
Node pl1, p2, head; 
// 确定 合并 后 的 头 结 点 
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if (headl1.data < head2.data) 
{ 
head = head 1] ; 
pl = headl.next; 
p2 = head2; 
} 
else 
{ 
head = head2; 
pl = headl; 
p2 = head2.next; 
} 
Node pcur = head,; 
while (pl != null && p2 != null) 
{ 
/ 把 链表 head1 当前 过 历 的 结 点 添加 到 合并 后 链表 的 尾部 
if (pl.data <= p2.data) 
{ 
peur.next= pl; 
pcur= pl; 
pl= pl.next; 
} 
// 把 链表 head2 当前 裔 历 的 结 点 添加 到 合并 后 链表 的 尾部 
else 
{ 
peur.next = p2; 
pcur = p2; 
p2 = p2.next; 
} 
/head2 链表 已 经 遍历 结束 ， 把 headl 遍历 剩余 的 结 点 添加 到 合并 后 链表 的 尾部 
if (pl != null) 
{ 
peur.next= pl; 
} 
if (p2 != null) 
{ 
pcurnext = p2; 
} 
} 
return head; 


当 使 用 方法 一 中 的 main 方法 进行 测试 时 ， 可 以 得 到 同样 的 运行 结果 。 


6. 答案 : 如 果 没 有 内 存 的 限制 ， 可 以 首先 将 文件 a 中 的 url 全 部 读 入 内 存 ， 放 到 HashSet 


中 ， 接 着 从 文件 b 
那么 这 个 url 就 是 这 两 个 文件 共同 的 url， 和 否则 不 是 。 
于 题目 要 求 内 存 大 小 只 有 4GB， 而 每 个 文件 的 大 小 为 50 亿 *64B=5*64GB=320GB， 远 


存在 ， 
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p 读 取 url， 每 读 取 一 个 url， 就 判断 这 个 url 在 HashSet 中 是 否 存在 ， 如 果 


真题 详解 篇 


远 超出 了 内 存 限 制 , 因此 , 无 法 一 次 将 所 有 url 读 取 到 内 存 中 , 此 时 可 以 采取 分 批 读 取 的 方法 。 
下 面 介绍 两 种 常用 的 方法 : 

方法 一 : Hash 法 

通过 对 url 求 Hash 值 ， 把 Hash 值 相 同 的 url 放 到 一 个 单独 的 文件 里 ， 这 样 就 可 以 把 50 
亿 个 url 分 解 成 数量 较 小 的 unl， 然后 一 次 读 入 内 存 进行 处 理 ， 具 体 实现 思路 如 下 : 

首先 遍历 文件 a， 对 每 个 url 求 Hash 值 并 散 列 到 1000 个 文件 中 ， 求 解 方法 为 
h=hash(url))%1000， 然 后 根据 Hash 的 结果 把 这 些 url 存放 到 文件 fa 中， 通过 散 列 ， 所 有 的 url 
将 会 分 布 在 (fa0，fa2，fa3，…，fa999) 这 1000 个 文件 中 。 每 个 文件 的 大 小 大 约 为 300MB。 
同 理 ， 将 文件 b 中 的 wl 也 以 同样 的 计算 方式 散 列 到 文件 fb 中， 所 有 的 url 将 会 分 布 在 〈fb0， 
fb1，fb2，…，fb999) 这 1000 个 文件 中 。 显 然 ， 与 fa0 中 相同 的 url 只 可 能 存在 于 fb0 中 ， 因 
此 ， 只 需要 分 别 找 出 文件 fai 与 fbi (0 和 ji 和 999) 中 相同 的 url 即 可 。 
此 外 ,如果 经 过 Hash 法 处 理 后 , 还 有 小 文件 占 的 内 存 大 小 超过 4GB， 此 时 可 以 采用 相同 
的 方法 把 文件 分 割 为 更 小 的 文件 进行 处 理 。 

方法 二 : Bloom filter 法 

日 常生 活 中 很 多 地 方 都 会 遇 到 类 似 这 样 的 问题 ， 例 如 ， 在 设计 计算 机 软件 系统 时 ， 在 程 
序 中 经 常 需要 判断 一 个 元 素 是 否 在 一 个 集合 中 ; 在 字 处 理 软件 中 ， 需 要 检查 一 个 英语 单词 是 
否 拼写 正确 ;在 FBI， 一 个 嫌疑 人 的 名 字 是 否 已 经 在 嫌疑 名 单 上 ; 在 网 络 爬 虫 里 ， 一 个 网 址 
是 否 被 访问 过 等 。 

针对 这 些 问 题 ， 最 直接 的 解决 方法 就 是 将 集合 中 全 部 的 元 素 都 存储 在 计算 机 中 ， 每 当 遇 
到 一 个 新 元 素 时 ， 就 将 它 和 集合 中 的 元 素 直接 进行 比较 即 可 。 这 种 做 法 虽然 能 够 准确 无 误 地 
完成 任务 ， 但 存在 一 个 问题 ， 就 是 比较 次 数 太 多 ， 效 率 比 较 低 ， 当 数据 量 不 大 时 ， 这 种 效率 
低 的 问题 并 不 显著 ， 但 是 当 数据 量 巨大 时 ， 例 如 在 海量 数据 信息 处 理 中 ， 存 储 效率 低 的 问题 
就 显现 出 来 了 。 例 如 邮箱 总 是 需要 过 滤 垃 圾 邮件 ， 一 种 办 法 就 是 记录 下 那些 发 垃圾 邮件 的 
Email 地 址 ， 可 是 由 于 那些 发 送 者 还 会 不 停 地 再 注册 新 的 地 址 ， 如 果 使 用 哈 希 表 ， 里 面 存储 一 
亿 个 Email 地 址 ， 一 般 而 言 ， 每 个 Email 地 址 需要 占用 16B， 所 以 ， 一 共 需 要 1 亿 *16B， 大 约 
1.6GB 的 内 存 ， 除 非 是 超级 计算 机 ， 一 般 服务 器 是 无 法 存储 如 此 海量 信息 的 。 

Bloom filter 正 是 解决 这 一 问题 的 有 效 方法 ， 它 是 一 种 空间 效率 和 时 间 效 率 很 高 的 随机 数 
据 结构 ， 用 来 检测 一 个 元 素 是 否 属于 一 个 集合 。 但 它 同样 带 来 一 个 问题 : 牺牲 了 正确 率 ， 
Bloom filter 以 牺牲 正确 率 为 前 提 ， 来 换取 空间 效率 与 时 间 效 率 的 提高 。 当 它 判断 某 元 素 不 属 
于 这 个 集合 时 ， 该 元 素 一 定 不 属于 这 个 集合 ; 当 它 判断 某 元 素 属 于 这 个 集合 时 ， 该 元 素 不 一 
定 属 于 这 个 集合 。 有 具体 而 言 ,， 查询 结果 有 两 种 可 能 ， 即 “不 属于 这 个 集合 〈 绝 对 正确 )” 和 “ 属 
于 这 个 集合 (可 能 错误 )”。 所 以 ，Bloom filter 适合 应 用 在 对 于 低 错 误 率 可 以 容忍 的 场合 。 

它 的 基本 原理 是 位 数组 与 Hash 函数 的 联合 使 用 。 有 具体 而 言 ， 首 先 ，Bloom filter 是 一 个 包 
含 了 m 位 的 位 数组 ， 数 组 的 每 一 位 都 初始 化 为 0， 然 后 定义 k 个 不 同 的 Hash 函数 ， 每 个 函数 
都 可 以 将 集合 中 的 元 素 映 射 到 位 数组 的 某 一 位 。 当 向 集合 中 插入 一 个 元 素 时 ， 根 据 k 个 Hash 
函数 可 以 得 到 位 数组 中 的 k 个 位 , 将 这 些 位 设置 为 1。 如 果 查 询 某 个 元 素 是 否 属于 和 集合， 那么 
根据 k 个 Hash 函数 可 以 得 到 位 数组 中 的 k 个 位 ， 查 看 这 个 位 中 的 值 ， 如 果 有 的 位 不 为 1， 
那么 该 元 素 肯 定 不 在 此 集合 中 ; 如 果 这 个 位 全 部 为 1， 那么 该 元 素 可 能 在 此 集合 中 (在 插入 
其 他 元 素 时 ， 可 能 会 将 这 些 位 置 为 1， 这 样 就 产生 了 错误 )。 
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下 面 通过 一 个 实例 具体 了 解 Bloom filter， 如 图 8 所 示 。 
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图 8 Bloom filter 实例 


所 以 ,使 用 Bloom filter 的 难点 是 如 何 根 据 输入 元 素 个 数 n， 来 确定 位 数组 m 的 大 小 以 及 
Hash 函数 。 当 Hash 函数 个 数 k=(In2)*(nyn) 时 错误 紊 最小， 在 错误 率 不 大 于 的 情况 下 ，m 
至 少 要 等 于 nx*lg(1/E) 才 能 表示 任意 n 个 元 素 的 集合 。 但 m 还 应 该 更 大 些 ， 因 为 还 要 保证 位 数 
组 里 至 少 一 半 为 0， 则 m 应 该 大 于 等 于 nxlg(I/E)*lge 大 约 为 nx*lg(1/E) 的 1.44 倍 (lg 表示 以 2 
为 底 的 对 数 )。 

例如 假设 三 为 0.01， 即 错误 率 为 0.01， 则 此 时 m 应 该 大 约 为 n 的 13 倍 ， 这 样 k 大约 是 8 
个 (注意! m 与 n 的 单位 不 同 ，m 的 单位 是 bit， 而 n 则 是 以 元 素 个 数 为 单位 )。 通 常 单个 元 
素 的 长 度 都 是 有 很 多 bit 的 ， 所 以 ， 使 用 Bloom filter 内 存 通常 都 是 节省 的 。 

Bloom filter 的 优点 是 具有 很 好 的 空间 效率 和 时 间 效 紊 。 它 的 插入 和 查询 时 间 都 是 常数 ， 
另外 它 不 保存 元 素 本 身 ， 具 有 和 良好 的 安全 性 。 然 而 ， 这 些 优点 都 是 以 牺牲 正确 率 为 代价 的 。 
当 揪 入 的 元 素 越 多 ， 错 判 “ 元 素 属 于 这 个 集合 ”的 概率 就 越 大 。 另 外 ，Bloom filter 只 能 插入 
元 素 ， 却 不 能 删除 元 素 ， 因 为 多 个 元 素 的 Hash 结果 可 能 共用 了 Bloom filter 结构 中 的 同一 个 
位 ， 如 果 删 除 元 素 ， 就 可 能 会 影响 多 个 元 素 的 检测 。 所 以 ，Bloom filter 可 以 用 来 实现 数据 字 
典 、 a 求 交 集 。 

对 于 本 题 而 言 : 4GB 内 存 可 以 表示 340 亿 bit， 把 文件 a 中 的 url 采用 Bloom filter 方法 映 
射 到 这 340 亿 bit 上 , 然后 遍历 文件 b, 判断 是 否 存在 。 但 是 采用 这 种 方法 会 有 一 定 的 错误 率 ， 
只 有 当 人 允许 有 一 定 的 错误 率 的 时 候 才 可 以 使 用 这 种 方法 。 


aa 攻 蚊 某 知 名 安全 软件 服务 提供 商 软件 
工程 师 笔 试题 
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instanceof 是 Java 语言 中 的 一 个 二 元 运算 符 , 它 的 作用 是 判断 一 个 引用 类 型 的 变量 所 指向 
的 对 象 是 否 是 一 个 类 (或 接口 、 抽 象 类 、 父 类 ) 的 实例 ， 即 它 左 边 的 对 象 是 否 是 它 右边 的 类 
的 实例 ， 返 回 boolean 类 型 的 数据 。 

常见 的 用 法 如 下 : result = object instanceof class， 如 果 object 是 class 的 一 个 实例 ， 那 么 
instanceof 运算 符 返 回 true; 如 果 object 不 是 指定 类 的 一 个 实例 ， 或 者 object 是 null， 那 么 ， 
此 时 返回 false。 

在 Java 语言 中 ， 所 有 类 都 是 Object 的 子 类 ， 由 于 “hello” 是 字符 串 类 型 (String)，String 
是 Object 的 子 类 ， 因 此 ,“hello” 也 是 Object 类 , “hello”instanceof Object 的 返回 值 为 true。 
所 以 ， 选 项 B 正确 。 

所 以 ， 本 题 的 答案 为 B。 

2. 管 案 : B。 

分 析 : 本 题 考察 的 是 对 方法 覆盖 的 理解 。 

履 盖 《Override) 是 指派 生 类 方法 覆盖 基 类 方法 ， 履 盖 一 个 方法 并 对 其 重 写 ， 以 起 到 不 同 
的 作用 。 在 使 用 履 盖 时 需要 注意 以 下 几 点 : 

1) 派生 类 中 的 歼 盖 方法 必须 要 和 基 类 中 被 覆盖 方法 有 相同 的 函数 名 和 参数。 

2) 派生 类 中 的 覆盖 方法 的 返回 值 必须 和 基 类 中 被 覆盖 方法 的 返回 值 相 同 。 

3) 基 类 中 被 覆盖 的 方法 不 能 为 private， 和 否则 ， 其 子 类 只 是 定义 了 另外 一 个 方法 ， 并 没有 
对 其 禾 盖 。 

4) 子 类 方法 不 能 缩小 父 类 方法 的 访问 权限 。 

5) 子 类 方法 不 能 抛 出 比 父 类 方法 更 多 的 异常 。 
1 此 可 见 ， 履 盖 方 法 与 被 覆盖 的 方法 可 以 有 不 同 的 访问 权限 。 所 以 ， 选 项 A、 选 项 C 与 
选项 DD 正确 ， 而 选项 B 错误 。 

所 以 ， 本 题 的 答案 为 B。 

3. 答案 : A。 

分 析 : 本 题 考察 的 是 对 Java 代码 整体 结构 的 理解 。 

package 是 Java 语言 所 特有 的 内 容 ， 它 的 作用 就 是 把 若干 类 按 包 结构 进行 分 类 管理 ， 最 
重要 的 用 途 是 为 了 解决 同名 但 作用 不 同 的 类 同时 存在 的 问题 。 

import 语句 允许 开发 人 员 在 编译 时 将 其 他 类 的 源 代码 包含 到 源 文 件 中 ， 
语句 包括 import 关键 字 、 以 点 (.) 分 隔 的 包 路 笃 、 类 名 或 星 号 (*)。 需 要 注意 的 是 ， 每 条 import 
语句 只 可 以 对 应 一 个 包 。 

在 Java 语言 中 ，package 语句 必须 作为 Java 源 文件 的 第 一 条 语句 ， 指 明 该 文件 中 定义 的 
类 所 在 的 包 。 所 以 ， 如 果 代 码 中 有 package 语句 ， 则 必须 放 在 最 前 面 ， 即 该 语句 必须 放 在 代 
码 的 第 一 行 〈 不 考虑 注释 和 空格 )。 因 此 ， 选 项 A 正确 ， 选 项 B 和 选项 C 错误 。 

对 于 选项 D，Java 类 或 接口 有 如 下 命名 规则 : 被 public 修饰 的 类 或 者 接口 必须 与 文件 名 
相同 。 因 此 ， 选 项 D 错误 。 

所 以 ， 本 题 的 答案 为 A。 

4. 答案 : B、C、D、E。 

分 析 : 本 题 考 察 的 是 对 Java 变量 命名 规则 的 理解 。 

对 于 选项 A， 由 于 变量 名 不 能 以 数字 开头 ， 所 以 ， 它 不 是 合法 的 标识 符 。 所 以 ， 选 项 A 
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普 误 。 


对 于 选项 F， 由 于 变量 名 不 能 以 #7 


开头 ， 所 以 ， 它 不 是 合法 的 标识 符 。 所 以 ， 选 项 F 错误 。 


对 于 选项 B、 选 项 C、 选 项 D 和 选项 E， 都 满足 标识 符 的 定义 。 所 以 ， 选 项 B、 选 项 C、 


人 


选项 D 和 选项 E 都 是 正确 


的。 


所 以 ， 本 题 的 答案 为 B、C、D、E。 


5. 答案 : C。 


分 析 : 本 题 考察 的 是 对 Java 运行 环境 的 理解 。 


Java 程 


件 平台 是 相关 的 。 


从 以 上 分 析 可 知 ，Java 程序 的 下 一 层 环境 为 JVM， 而 JVM 是 运行 在 操 
因此 ， 一 个 Java 程 


作 系 统 又 运行 在 便 件 上 。 
JRE/JYM、 操 作 系 统 和 硬 伯 


所 以 ， 本 题 的 答案 为 C。 


6. 


答案 : A。 


Java 接口 是 一 系列 方法 的 声明 ， 是 一 些 方法 特征 的 集合 。 
这 些 方法 可 以 在 不 同 的 地 方 被 不 同 的 类 实 
FP 定义 的 成 员 变 量 默认 为 public static final， 只 能 够 有 静态 上 
L， 必 须 给 其 赋 初 值 ， 其 所 有 的 成 员 方 法 都 是 public、abstract 


没有 方法 的 实现 ， 
不 同 的 行为 (功能 


而 且 


上 


因此 ， 
。 通 常 ， 接 口上 
不 能 被 修改 的 数据 成 员 ， 而 上 
只 能 被 这 两 个 关键 字 修 饰 。 

从 以 上 分 析 可 知 ， 只 有 关键 字 static 可 以 


执行 的 代码 。 由 上 


分 析 : 本 题 考察 的 是 对 接口 的 理解 。 


所 以 ， 本 题 的 答案 为 A。 


7. 答案 : D。 


序 被 编译 后 并 不 是 生成 能 在 硬件 平台 上 可 执行 的 代码 , 而 是 生成 了 一 个 中 间 代 码 。 
不 同 的 硬件 平台 上 会 安装 有 不 同 的 JVM (Java Virtual Machine，Java 虚拟 机 )，! 
责 把 中 间 代 码 翻译 成 硬件 平台 能 


JVM 来 负 


可 以 看 出 ，JVM 不 具有 平台 独立 性 ， 与 硬 


作 系统 上 的 ， 操 


序 运 行 的 环境 次 序 从 上 到 下 是 Java 程序 、 
F。 所 以 ， 选 项 C 正确 。 


一 个 接口 具有 方法 的 声明 ， 但 
现 ， 


而 这 些 实现 可 以 具有 
日 


的 > 


来 修饰 接口 


分 析 : 本 题 考察 的 是 对 String 的 理解 。 


在 Java 语言 
方法 ， 因 此 ， 会 多 


正 硼 


字符 的 方法 ，charAt0 方 法 返回 指定 索引 位 置 的 char 值 


上 日. 7 信人 


length0) 人 返回 的 是 字条 


8. 答案 : D。 


中 ，String 是 一 个 特殊 
i 译 失 败 ， 所 以 ， 选 项 DD 正确 。 
角 的 方法 应 该 是 charAt，charAt(int index) 方 法 是 一 个 能 够 月 
。 索 引 范 围 为 0~lengthO0-1， 其 ， 


的 包装 类 数据 ,本题 9 


的 变量 。 


因此 ， 选 项 A 正确 。 


PF， 由 于 String 类 中 没有 charA:O 


日 来 检索 特定 索引 下 的 


串 的 长 度 ， 例 如 ，strcharAt(0) 检 索 字 符 串 str 中 的 第 一 个 字符 ， 
strcharAt(strlengthO-1) 检 索 字 符 串 str 的 最 后 一 个 字符 。 
所 以 ， 本 题 的 答案 为 D。 


分 析 : 本 题 考察 的 是 对 Map 


Java 为 数据 结构 中 的 映射 
Hashtable 和 TreeMap。 1 


个 接口 ， 
本 


因为 new 
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的 弄 


E 解 。 


义 了 一 个 接口 java.util.Map， 它 有 三 个 实 1 


现 类 : HashMap、 


于 接 


中 的 方法 都 没有 实现 ， 
只 能 用 来 实例 化 非 抽象 的 类 。 所 以 ， 选 项 D 正 
题 中 , 一 种 正确 的 写法 为 Map<String,String> m=new HashMap<String,String>0， 把 实例 


确 。 


因此 ， 不 能 直接 使 用 new 来 实例 化 一 
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化 HashMap 对 象 的 实例 赋值 给 Map 接口 变量 m。 
所 以 ， 本 题 的 答案 为 D。 


9. 答案 : A。 
10. 答案 : A。 


分 析 : 本 题 考察 的 是 对 重 载 的 理解 。 
重 载 是 在 一 个 类 中 多 态 性 的 一 种 表现 ， 是 指 在 一 个 类 中 定义 了 多 个 同名 的 方法 ， 它 们 或 
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1) 重 载 是 通过 不 同 的 方法 参数 来 区 分 的 ， 例 如 ， 不 同 的 参数 个 数 、 不 同 的 参数 类 型 或 不 


2) 不 能 通过 方法 的 访问 权限 、 返 回 值 类 型 和 抛 出 的 异常 类 型 来 进行 重 载 。 

本 题 中 ， 对 于 选项 A， 重 载 采 用 不 同 的 形式 参数 列表 。 所 以 ， 选 项 A 正确 。 

对 于 选项 B， 重 载 不 能 用 返回 值 来 区 分 。 所 以 ， 选 项 B 错误 。 

对 于 选项 C， 重 载 是 在 一 个 类 中 多 态 性 的 表现 ， 因 此 ， 所 有 重 载 的 方法 都 属于 同一 个 类 ， 
它们 使 用 不 同 的 参数 列表 来 区 分 ， 无 法 通过 对 象 前 缀 区分。 所以， 选项 C 错误 。 

对 于 选项 D， 如 果 不 同名 的 参数 有 相同 的 类 型 ， 也 无 法 区 分 。 所 以 ， 选 项 D 错误 。 

所 以 ， 本 题 的 答案 为 A。 

11. 答案 : B。 

分 析 : 本 题 考察 的 是 对 构造 方法 的 理解 。 

构造 方法 是 一 种 特殊 的 方法 ， 主 要 用 来 在 创建 对 象 时 初始 化 对 象 ， 即 为 对 象 成 员 变 量 赋 
初始 值 。 

本 题 中 ， 对 于 选项 A 与 选项 B， 构 造 方法 必须 与 类 的 名 字 相 同 ， 并 且 不 能 有 返回 值 ( 返 
器 值 也 不 能 为 void 类 型 )。 因 此 ， 选 项 A 错误 ， 选 项 B 正确 。 

对 于 选项 C， 构 造 方法 是 在 对 象 被 创建 的 时 候 由 编译 器 调用 的 ， 程 序 员 无 法 直接 调用 构 
造 方法 。 因 此 ， 选 项 C 错误 。 

对 于 选项 D， 如 果 程 序 员 没 有 提供 构造 方法 ， 编 译 器 会 提供 一 个 默认 的 构造 方法 。 因 此 ， 
选项 DD 错误 。 

所 以 ， 本 题 的 答案 为 了 B。 

12. 答案 ， A。 

分 析 : 本 题 考 察 的 是 对 继承 的 理解 。 

本 题 中 ， 继 承 是 从 已 有 的 类 中 派生 出 新 的 类 ， 新 的 类 能 吸收 已 有 类 的 数据 属性 和 行为 ， 
并 能 扩展 新 的 能 力 ， 子 类 能 继承 父 类 的 公有 和 受 保护 的 方法 和 属性 ， 但 是 不 能 继承 私有 方法 
和 属性 。 所 以 ， 选 项 A 正确 ， 选 项 B、 选 项 C 与 选项 DD 错误 。 

所 以 ， 本 题 的 答案 为 A。 

13. 答案 ， D。 

分 析 : 本 题 考 察 的 是 在 继承 情况 下 构造 方法 的 使 用 方法 。 

对 于 选项 A， 当 创建 子 类 对 象 的 时 候 ， 必 定 会 首先 调用 父 类 的 构造 方法 ， 然 后 再 调用 子 
类 的 构造 方法 。 因 此 ， 选 项 A 错误 。 

对 于 选项 B 与 选项 D， 由 于 构造 方法 是 不 能 被 继承 的 ， 因 此 ， 选 项 B 错误 ， 选 项 D 正确 。 

对 于 选项 C， 当 子 类 没有 显 式 地 调用 构造 方法 的 时 候 ， 编 译 器 会 自动 调用 父 类 的 无 参数 
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的 构造 方法 ， 因 此 ， 子 类 可 以 不 通过 super0 方 法 调用 父 类 的 构造 方法 。 因 此 ， 选 项 C 错误 。 

所 以 ， 本 题 的 答案 为 D。 

14. 答案 : A。 

分 析 : 本 题 考察 的 是 面向 对 和 象 的 基础 知识 。 

对 于 选项 A， 类 可 以 被 理解 为 变量 和 方法 的 集合 体 。 因 此 ， 选 项 A 正确 。 

对 于 选项 B， 抽 象 类 是 不 能 被 实例 化 的 ， 只 有 实现 了 抽象 类 的 具体 类 才能 被 实例 化 。 接 
口 也 不 能 被 实例 化 ， 只 有 实现 了 接口 方法 的 类 才能 被 实例 化 。 因 此 ， 选 项 B 错误 。 

对 于 选项 C， 数 组 是 一 些 相 同类 型 数据 的 集合 ， 而 描述 中 没有 提 到 相同 类 型 ， 不 是 很 合 
理 。 因 此 ， 选 项 C 错误 。 

对 于 选项 D， 类 的 数据 类 型 可 以 是 公开 的 ， 也 可 以 是 私有 的 ， 由 于 面向 对 象 封装 的 特点 ， 
一 般 会 把 成 员 数 据 设计 为 私有 的 ， 然 后 提供 公有 的 方法 对 其 访问 。 因 此 ， 选 项 DD 错误 。 

所 以 ， 本 题 的 答案 为 A。 

15. 答案 : A。 

分 析 : 本 题 考察 的 是 面向 对 和 象 的 基础 知识 。 

类 A 是 main 方法 内 部 的 一 个 内 部 类 ， 执行 new A0 的 时 候 初 始 化 了 一 个 A 的 对 象 ， 这 个 
对 象 的 属性 i 的 值 为 3， 经 过 类 型 转换 后 ， 最 终 a 是 这 个 对 象 的 引用 ， 因 此 ， 输 出 结果 为 =3。 
所 以 ， 选 项 A 正确 。 

所 以 ， 本 题 的 答案 为 A。 

二 、 填 空 题 

1. 答案 : abstract，final。 

分 析 : 当 一 个 类 被 声明 为 final 时 ， 此 类 不 能 被 继承 ， 所 有 方法 都 不 能 被 重 写 。 

如 果 一 个 类 中 包含 抽象 方法 ， 那 么 这 个 类 就 是 抽象 类 。 在 Java 语言 中 ， 可 以 通过 把 类 或 
者 类 中 的 某 些 方法 声明 为 abstract 来 表示 一 个 类 是 抽象 类 。 

2. 答案 ;静态 成 员 变 量 初始 化 ， 成 员 变 量 初始 化 ， 构 造 方法 。 

分 析 : 当 类 第 一 次 被 加 载 的 时 候 ， 静 态 变量 会 首先 初始 化 ， 接 着 编译 器 会 把 实例 变量 初 
始 化 为 默认 值 ， 然 后 执行 构造 方法 。 

Java 程序 的 初始 化 一 般 遵 循 以 下 三 个 原则 (以 下 三 原则 优先 级 依次 递减 ): 中 静态 对 象 ( 变 
量 ) 优先 于 非 静态 对 象 〈 变 量 ) 初始 化 ， 其 中 ， 静 态 对 象 〈 变 量 ) 只 初始 化 一 次 ， 而 非 静态 
对 象 〈 变 量 ) 可 能 会 初始 化 多 次 ; 四 父 类 优先 于 子 类 进行 初始 化 ;@@ 按 照 成 员 变 量 定义 顺序 
进行 初始 化 。 即 使 变量 定义 散布 于 方法 定义 之 中 ， 它 们 依然 在 任何 方法 〈 包 括 构造 方法 ) 被 
调用 之 前 先 初始 化 。 

Java 程序 初始 化 工作 可 以 在 许多 不 同 的 代码 块 中 来 完成 (例如 静态 代码 块 、 构 造 方法 等 )， 
它们 执行 的 顺序 如 下 : 父 类 静态 变量 、 父 类 静态 代码 块 、 子 类 静态 变量 、 子 类 静态 代码 块 、 
父 类 非 静态 变量 、 父 类 非 静 态 代码 块 、 父 类 构造 方法 、 子 类 非 静 态 变量 、 子 类 非 静态 代码 块 
及 子 类 构造 方法 。 

3. 答案 ， 2，4。 

分 析 : Java 语言 一 共 提 供 了 8 种 原始 的 数据 类 型 (byte、short、int、long、float、double、 
char 和 boolean)， 这 些 数据 类 型 不 是 对 象 ， 而 是 Java 语言 中 不 同 于 类 的 特殊 类 型 ， 这 些 基 本 
类 型 的 数据 变量 在 声明 之 后 就 会 立刻 在 栈 上 分 配 内 存 空 间 。 除 了 这 8 种 基本 的 数据 类 型 外 ， 
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其 他 的 类 型 都 是 引用 类 型 〈 例 如 类 、 接 口 和 数组 等 )， 引 用 类 型 类 似 于 C++ 语言 中 的 引用 或 指 

针 的 概念 ， 它 以 特殊 的 方式 指向 对 象 实 体 ， 这 类 变量 在 声明 时 不 会 被 分 配 内 存 空间 ， 只 是 存 

储 了 一 个 内 存 地 址 而 已 。 
Java 语言 中 基本 数据 类 型 及 其 描述 见 表 6。 

表 6 Java 语言 中 基本 数据 类 型 及 其 描述 


数据 类 型 字 节 长 度 /B 范 围 默 认 值 包 装 类 
int 4 [2147483648, 2147483647] (-23 一 23-1D) | 0 Integer 
short 2 [-32768, 32767] 0 Short 
we | 
byte 1 广 128, 127] 0 Byte 
float 4 32 位 IEEE754 单 精度 范围 0.0F 或 0.0f Float 
double 8 64 位 IEEE754 双 精 度 范围 0.0 Double 
char 2 Unicode[0,65535] u0000 Character 
boolean 】 true 和 false false Boolean 


对 于 boolean 类 型 占用 空间 的 大 小 问题 ， 从 理论 上 讲 , 只 需要 lbit 就 够 了 , 但 在 设计 的 时 
候 ， 为 了 考虑 字 节 对 齐 等 因素 ， 一 般 会 考虑 使 其 占用 一 个 字 节 。 由 于 Java 规范 没有 明确 的 规 
定 ， 因 此 ， 不 同 的 JVM 可 能 会 有 不 同 的 实现 。 

4. 答案 : 继承 Thread 类 ， 实 现 Runnable 接 

5. 答案 : 重 载 ， 多 态 。 

多 态 是 面向 对 象 程序 设计 中 代码 重用 的 一 个 重要 机 制 ， 它 表示 当 同 一 个 操作 作用 在 不 同 
的 对 象 时 ， 会 有 不 同 的 语义 ， 从 而 会 产生 不 同 的 结果 。 在 Java 语言 中 ， 多 态 主要 有 以 下 两 种 
表现 方式 : 

(1) 重 载 (Overload ) 
重 载 是 指 同一 个 类 中 有 多 个 同名 的 方法 ， 但 这 些 方法 却 有 着 不 同 的 参数 ， 因 此 ， 在 编译 
的 时 候 就 可 以 确定 到 底 调 用 的 是 哪个 方法 ， 它 是 一 种 编译 时 多 态 。 重 载 可 以 被 看 作 一 个 类 中 
的 方法 多 态 性 。 

(2) 窗 盖 (Override) 

子 类 可 以 覆盖 父 类 的 方法 ， 因 此 ， 同 样 的 方法 会 在 父 类 与 子 类 中 有 着 不 同 的 表现 形式 。 
在 Java 语言 中 ， 基 类 的 引用 变量 不 仅 可 以 指 问 基 类 的 实例 对 象 ， 也 可 以 指向 其 子 类 的 实例 对 
象 。 同 样 ， 接 口 的 引用 变量 也 可 以 指向 其 实现 类 的 实例 对 象 。 而 程序 调用 的 方法 在 运行 期 才 
动态 绑 定 〈 绑 定 指 的 是 将 一 个 方法 调用 和 一 个 方法 主体 连接 到 一 起 )， 就 是 引用 变量 所 指向 的 
具体 实例 对 象 的 方法 ， 也 就 是 内 存 里 正在 运行 的 那个 对 象 的 方法 ， 而 不 是 引用 变量 的 类 型 中 
定义 的 方法 。 通 过 这 种 动态 绑 定 的 方法 实现 了 多 态 。 由 于 只 有 在 运行 时 才能 确定 调用 的 是 哪 
个 方法 ， 因 此 ， 通 过 方法 覆 善 实现 的 多 态 也 可 以 被 称 为 运行 时 多 态 。 如 下 例 所 示 ; 


AAA 


class Base 
{ 
public Base() 
{ 
g0); 
} 
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public void f() 


System.out.println("Base f()"); 


} 
public void g() 


{ 


System.out.println("Base gO)"); 


} 


} 


class Derived extends Base 


{ 
public void f() 


{ 


System.out.println("Derived f()"); 


} 
public void g() 


{ 


System.out.printin("Derived gO)"); 


} 


} 


public class Test 


{ 


public static void main(String[] args) 


{ 


Base b=new Derived(); 
b.fO; 
b.g0; 


程序 的 输出 结果 为 


Derived g() 
Derived f() 
Derived g() 


上 例 中 ， 由 于 子 类 Derived 的 f 和 方法 和 g0 方 法 与 父 类 Base 的 方法 同名 ， 因 此 ，Derived 
的 方法 会 覆盖 父 类 Base 的 方法 。 在 执行 Base b = new Derived0 语 句 的 时 候 , 会 调用 Base 类 的 
构造 方法 ， 而 在 Base 的 构造 方法 中 ， 执 行 了 g0 方 法 ， 由 于 Java 语言 的 多 态 特 性 ， 此 时 会 调 
用 子 类 Derived 的 g0 方 法 ， 而 非 父 类 Base 的 g0 方 法 ， 因 此 ， 会 输出 Derived g0。 由 于 实际 
创建 的 是 Derived 类 的 对 象 ， 后 面 的 方法 调用 都 会 调用 子 类 Derived 的 方法 。 

三 、 问 答题 
1. 答案 : 接口 可 以 继承 接口 ， 抽 象 类 可 以 实现 接口 ， 而 抽象 类 不 能 继承 实体 类 。 
2. 答案 : 面向 对 象 的 主要 特征 有 抽象 、 继 承 、 封 装 及 多 态 。 以 下 将 分 别 对 这 几 种 特性 进 
乡 
1 


行 介 


) 抽象 : 抽象 就 是 忽略 一 个 主题 中 与 当前 目标 无 关 的 那些 方面 ， 以 便 更 充分 地 注意 与 当 
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前 目标 有 关 的 方面 。 抽 象 并 不 打算 了 解 全 部 问题 ， 而 只 是 选择 其 中 的 一 部 分 ， 和 暂时 不 用 关注 
细节 。 抽 象 包括 两 个 方面 内 容 ， 一 是 过 程 抽 象 ， 二 是 数据 抽象 。 

2) 继承 : 继承 是 一 种 联结 类 的 层次 模型 ， 并 且 允 许 和 鼓励 类 的 重用 ， 它 提供 了 一 种 明确 
表述 共性 的 方法 。 对 象 的 一 个 新 类 可 以 从 现 有 的 类 中 派生 ， 这 个 过 程 称 为 类 继承 。 新 类 继承 
了 原始 类 的 特性 ， 新 类 称 为 原始 类 的 派生 类 〈 子 类 )， 而 原始 类 称 为 新 类 的 基 类 ( 父 类 )。 派 
生 类 可 以 从 它 的 基 类 那里 继承 方法 和 实例 变量 ， 并 且 子 类 可 以 修改 或 增加 新 的 方法 使 之 更 适 
合 特殊 的 需要 。 

3) 封装 : 封装 是 指 将 客观 事物 抽象 成 类 ， 每 个 类 对 自身 的 数据 和 方法 实行 保护 。 类 可 以 
把 自己 的 数据 和 方法 只 让 可 信 的 类 或 者 对 象 操作 ， 对 不 可 信 的 进行 信息 隐藏 。 

4) 多 态 : 多 态 是 指 允 许 不 同类 的 对 象 对 同一 消息 做 出 响应 。 多 态 包 括 参数 化 多 态 和 包含 
多 态 。 多 态 性 语言 具有 有 灵活、 抽象 、 行 为 共享 和 代码 共享 的 优势 ， 很 好 地 解决 了 应 用 程序 方 
法 同名 问题 。 

3. 答案 : String 用 于 字符 串 操 作 ， 属 于 不 可 变 类 ， 而 StringBuffer 也 是 用 于 字符 串 操 作 ， 
不 同 之 处 是 StringBuffer 属于 可 变 类 。 

String 是 不 可 变 类 , 也 就 是 说 , String 对 象 一 旦 被 创建 , 其 值 将 不 能 被 改变 , 而 StringBuffer 
是 可 变 类 ， 当 对 和 象 被 创建 后 ， 仍 然 可 以 对 其 值 进行 修改 。 如 果 一 个 字符 串 经 常 需要 被 修改 的 
时 候 ， 使 用 StringBuffer 有 更 高 的 效率 。 

为 了 更 好 地 说 明 这 一 问题 ， 下 面 分 析 一 个 示例 。 


public class Test 


{ 
public static void testString() 
{ 
String s = "Hello"; 
String sl = "world"; 
long start = System.currentTimeMillis(); 
for (inti= 0;1< 10000; i++) 
{ 
s+= sl; 
} 
long end = System.currentTime Millis(); 
long runTime = (end - start); 
System.out.println("testString:" + runTime); 
} 
public static void testStringBuffer() 
{ 


StringBuffer s = new StringBuffer("Hello"); 
String sl = "world"; 
long start = System.currentTimeMillis(); 
for (inti= 0;1i< 10000; i++) 
{ 

s.append(s1); 


} 
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long end = System.currentTime Millis(); 
long runTime = (end - start); 


? 


System.out.println("testStringBuffer:" + TunTime) 


} 


public static void main(String[] args) 


{ 
testString(); 
testStringBuffer(); 


} 


程序 的 运行 结果 为 


testString:1760 
testStringBuffer:3 


从 程序 的 运行 结果 


String 的 性 能 要 


使 月 


好 很 多 。 


可 以 看 出 ， 当 一 个 字符 串 需 要 经 常 被 修改 的 时 候 , 使 用 StringBuffer 比 


4. 答案 : final、finally 和 finalize 的 区 别 如 下 : 


类 , 分 


1) final 用 于 声明 属性 、 方 法 和 
(不 能 再 派生 出 新 的 子 类 )。 


别 表 示 属 性 不 


口 


J 变 、 方 法 不 可 覆盖 、 类 不 可 被 继承 


final 属性 :被 fnal 修饰 的 变量 不 可 变 


， 由 于 不 可 变 有 了 两 


EE 含义 ， 一 是 引用 不 可 变 ， 二 是 


对 象 不 可 变 。 那 么 final 到 底 指 的 是 哪 种 含义 呢 ? 下 面 通 过 一 个 例子 来 进行 说 明 。 


public class Test 
public static void main(String[] arg) 
final StringBuffer s=new StringBuffer("Hello"); 
s.append(" world"); 
System.out.printlin(S); 
} 
} 


public class Test 


{ 


public static void main(String[] arg) 


{ 
final StringBuffer s=new StringBuffer("Hello"); 
s=new StringBuffer("Hello world"); 


} 


运行 结果 为 : 编译 期 间 错误 
Hello world 

从 以 上 例子 中 可 以 看 出 ，final 指 的 是 引用 的 不 可 变性 ， 即 它 只 能 指向 初始 时 指向 的 那个 
对 象 ， 而 不 关心 指向 对 象 内 容 的 变化 。 所 以 ， 被 final 修饰 的 变量 必须 被 初始 化 。 一 般 可 以 通 


过 


始 


化 ; 外 在 类 的 构造 器 ， 


各 


然 可 以 使 用 这 个 方法 。 另 外 还 有 一 下 


初始 化 ， 但 静态 final 成 员 变 量 不 可 以 在 构造 方法 中 初始 化 。 
final 方法 : 当 一 个 方法 声明 为 final 时 ， 该 方法 不 允许 任何 子 类 习 
被 称 为 inline〈 内 联 ) 的 机 


[以 下 几 种 方式 对 其 进行 初始 化 : 包 在 定义 的 时 候 初始 化 ;final 成 员 变 量 可 以 在 初始 化 块 
初始 化 ， 但 不 可 在 静态 初始 化 块 中 初始 化 ; @@ 静 态 final 成 员 变 量 可 以 如 


E 静 态 初始 化 块 中 初 


E 写 这 个 方法 ， 但 子 类 仍 
吓 ， 当 调用 一 个 被 声明 为 final 


的 方法 时 ， 
这 样 做 能 提高 程序 的 效率 。 


直接 将 方法 主体 插入 到 调用 处 , 而 不 是 进行 方法 调用 (类 似 于 C++ 语言 


中 的 inline )， 


final 参数 : 用 来 表示 这 个 参数 在 这 个 方法 内 部 不 允许 被 修改 。 
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final 类 : 当 一 个 类 被 声明 为 final 时 ， 此 类 不 能 被 继承 ， 所 有 方法 都 不 能 被 重 写 。 但 
这 并 不 表示 final 类 的 成 员 变 量 也 是 不 可 改变 的 , 要 想 做 到 final 类 的 成 员 变 量 不 可 改变 ， 
必须 给 成 员 变 量 增加 final 修饰 。 值 得 注意 的 是 ， 一 个 类 不 能 既 被 声明 为 abstract， 又 被 
声明 为 final。 

2) finally 作为 异常 处 理 的 一 部 分 , 它 只 能 用 在 try/catch 语句 中 , 并 且 附 带 着 一 个 语句 块 ， 
表示 这 段 语 名 最 终 一 定 被 执行 ， 经 常 被 用 在 需要 释放 资源 的 情况 下 。 示 例 1: 不 使 用 finally 
的 代码 如 下 所 示 : 


Connection conn; 
Statement stmt; 
try 


{ 
String url="jdbc:sqlserver://localhost: 1433;DatabaseName=dbName"; 


1 1 


conn = DriverManager.getConnection(url, "username", "password"); 
stmt = conn.createStatement(); 
stmt.executeUpdate(update);。// 执 行 一 条 update 语句 ， 此 时 出 现 异 常 
stmt.close(); 
conn.close(); 
} catch (Exception e) { 


} 


在 上 面 的 程序 片段 中 ， 如 果 程 序 在 运行 过 程 中 没有 发 生 异 常 ， 那 么 数据 库 的 连接 能 够 得 
到 释放 ， 程 序 运 行 没 有 问题 。 如 果 在 执行 update 语句 时 出 现 异常 ， 后 面 的 close0 方 法 将 不 会 
被 调用 ， 数 据 库 的 连接 将 得 不 到 释放 。 如 果 有 大 量 的 这 种 程序 运行 ， 可 能 会 耗 光 数 据 库 的 连 
接 资 源 。 通 过 使 用 finally 可 以 保证 任何 情况 下 数据 库 的 连接 资源 都 能 够 被 释放 。 示 例 2: 使 
用 finally 代码 如 下 所 示 : 


三 
起 
二 
过 


Connection conn = null; 
Statement stmt = null; 
try 
{ 
String url="jdbc:sqlserver://localhost: 1433;DatabaseName=dbName"; 


conn = DriverManager.getConnection(url, "username", "password"); 
stmt = conn.createStatement(); 
stmt.executeUpdate("select * from table"); // 执行 一 条 update 语句 ， 此 时 出 现 


stmt.close(); 


conn.close(); 
} catch (Exception e) 
{ 

// exception handling. 
} finally 
{ 

if (stmt != null) 

try { 
stmt.close(); 
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} catch (SQLException e) { 
} 
if (conn != null) 
try { 
stmt.close(); 


} catch (SQLException e) { 


} 


} 
在 上 面 的 代码 中 ， 不 管 程序 运行 是 否 会 出 现 异 常 ，finally 中 的 代码 一 定 会 执行 ， 这 样 能 
够 保证 在 任何 情况 下 数据 库 的 连接 都 能 被 释放 。 

3) finalize 是 Object 类 的 一 个 方法 ， 在 垃圾 收集 器 执行 的 时 候 会 调用 被 回收 对 象 的 
finalize() 方 法 ， 可 以 覆盖 此 方法 来 实现 对 其 他 资源 的 回收 ， 例 如 关闭 文件 等 。 需 要 注意 的 是 ， 
旦 垃圾 回收 器 准备 好 释放 对 象 占用 的 空间 ， 将 首先 调用 其 finalize() 方 法 ， 并 且 在 下 一 次 垃 
圾 回收 动作 发 生 时 ， 才 会 真正 回收 对 象 占 用 的 内 存 。 

5$. 答案 : ArrayList、Vector 和 LinkedList 类 均 在 java.util 包 中 ， 都 是 可 伸缩 的 数组 ， 即 
可 以 动态 改变 长 度 的 数组 。 

ArrayList 和 Vector 都 是 基于 存储 元 素 的 Object[] array 来 实现 的 ， 它 们 会 在 内 存 中 开辟 一 
块 连续 的 空间 来 存储 ， 由 于 数据 存储 是 连续 的 ， 因 此 ， 它 们 文 持 用 序号 〈 下 标 、 索 引 ) 来访 
问 元 素 ， 同 时 ， 索 引 数 据 的 速度 比较 快 。 但 是 在 插入 元 素 的 时 候 需要 移动 容器 中 的 元 素 ， 所 
以 ， 对 数据 的 插入 操作 执行 速度 比较 慢 。ArrayList 和 Vector 都 有 一 个 初始 化 的 容量 的 大 小 ， 
当 里 面 存储 的 元 素 超过 这 个 大 小 的 时 候 ， 就 需要 动态 地 扩充 它们 的 存储 空间 。 为 了 提高 程序 
的 效率 ， 每 次 扩充 容量 的 时 候 ， 不 是 简单 地 扩充 一 个 存储 单元 ， 而 是 一 次 就 会 增加 多 个 存储 
单元 。Vector 默认 扩充 为 原来 的 两 倍 〈 每 次 扩充 空间 的 大 小 是 可 以 设置 的 )， 而 ArrayList 默认 
扩充 为 原来 的 1.5 倍 〈 没 有 提供 方法 来 设置 空间 扩充 的 方法 )。 

ArrayList 与 Vector 最 大 的 区 别 就 是 synchronization (同步 ) 的 使 用 ， 没 有 一 个 ArrayList 
的 方法 是 同步 的 , 而 Vector 的 绝 大 多 数 的 方法 (例如 add、insert、remove、 set、equals 和 hashcode 
等 ) 都 是 直接 或 者 间接 同步 的 ， 所 以 ，Vector 是 线程 安全 的 ，ArrayList 不 是 线程 安全 的 。 正 
是 由 于 Vector 提供 了 线程 安全 的 机 制 ， 使 其 性 能 上 也 要 略 逊 于 ArrayList。 

LinkedList 是 采用 双向 列表 来 实现 的 ， 对 数据 的 索引 需要 从 列表 头 开始 遍历 ， 因 此 ， 随 机 
访问 的 效率 比较 低 ， 但 是 插入 元 素 的 时 候 不 需要 对 数据 进行 移动 ， 故 插入 效率 较 高 。 同 时 ， 
LinkedList 不 是 线程 安全 的 。 

那么 ， 在 实际 使 用 时 ， 如 何 从 这 几 种 容器 中 选择 合适 的 使 用 呢 ? 当 对 数据 的 主要 操作 为 
索引 或 只 在 集合 的 末端 增加 、 删 除 元素 ， 使 用 ArrayList 或 Vector 效率 比较 高 。 当 对 数据 的 操 
作 主 要 为 指定 位 置 的 插入 或 删除 操作 ， 使 用 LinkedList 效率 比较 高 。 当 在 多 线程 中 使 用 容器 
时 《 即 多 个 线程 会 同时 访问 该 容器 )， 选 用 Vector 较为 安全 。 

HashMap 和 Hashtable 的 区 别 如 下 : 

Java 为 数据 结构 中 的 映射 定义 了 一 个 接口 java.util.Map， 它 有 三 个 实现 类 : HashMap、 
Hashtable 和 TreeMap。 Map 是 用 来 存储 键 - 值 对 的 数据 结构 , 在 数组 中 通过 数组 下 标 来 对 其 内 
容 进行 索引 ， 而 在 Map 中 ， 则 是 通过 对 象 来 进行 索引 ， 用 来 索引 的 对 象 叫 作 key， 其 对 应 的 
对 象 叫 作 value。 
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HashMap 是 一 个 最 常用 的 Map， 它 根据 键 的 HashCode 值 存储 数据 ， 根 据 键 可 以 直接 获 
取 它 的 值 ， 具 有 很 快 的 访问 速度 。 由 于 HashMap 与 Hashtable 都 采用 了 Hash 方法 进行 索引 ， 
因此 ， 二 者 具有 许多 相似 之 处 ， 它 们 主要 有 如 下 的 一 些 区 别 ; 

1) HashMap 是 Hashtable 的 轻 量 级 实现 《〈 非 线程 安全 的 实现 )， 它 们 都 实现 了 Map 接口 ， 
主要 区 别 在 于 HashMap 允许 空 Cnull) 键 值 (key)〈 但 需要 注意 ，HashMap 最 多 只 人 允许 一 条 记 
录 的 键 为 null， 不 允许 多 条 记录 的 值 为 null)， 而 Hashtable 不 允许 空 null) 键 值 (key)。 

2) HashMap 把 Hashtable 的 contains 方法 去 挤 了 ， 改 成 containsvalue 和 containsKey。 
为 contains 方法 容易 引起 误解 。Hashtable 继承 自 Dictionary 类 , 而 HashMap 是 Javal.2 引进 的 
Map interface 的 一 个 实现 。 

3) Hashtable 的 方法 是 线程 安全 的 ， 而 HashMap 由 于 不 支持 线程 的 同步 ， 所 以 ， 它 不 是 
线程 安全 的 。 在 多 个 线程 访问 Hashtable 时 , 不 需要 开发 人 员 对 它 进行 同步 , 而 对 于 HashMap， 
开发 人 员 必 须 提 供 额外 的 同步 机 制 。 所 以 ， 效 率 上 HashMap 可 能 高 于 Hashtable。 

4) Hashtable 使 用 Enumeration 进行 遍历 ，HashMap 使 用 Iterator 进行 过 历 。 

5) Hashtable 和 HashMap 采用 的 hash/rehash 算法 都 几乎 一 样 ， 所 以 ， 性 能 不 会 有 很 大 的 
差异 。 

6) Hashtable 中 Hash 数组 默认 大 小 是 11， 增 加 的 方式 是 old*2+1。 在 HashMap 中 ，Hash 
数组 的 默认 大 小 是 16， 而 且 一 定 是 2 的 指数 。 

7) Hash 值 的 使 用 不 同 ，Hashtable 直接 使 用 对 象 的 HashCode。 

以 上 三 种 类 型 中 ， 使 用 最 多 的 是 HashMap 。HashMap 里 面 存 入 的 键 - 值 对 在 取出 的 时 候 
没有 固定 的 顺序 ， 是 随机 的 。 一 般 而 言 ， 在 Map 中 插入 、 删 除 和 定位 元 素 ，HashMap 是 最 
好 的 选择 。 由 于 TreeMap 实现 了 SortMap 接口 ， 能 够 把 它 保存 的 记录 根据 键 排序 ， 所 以 ， 取 
出 来 的 是 排序 后 的 键 - 值 对 , 如 果 需 要 按 自然 顺序 或 自 定 义 顺序 遍历 键 , 那么 TreeMap 会 更 好 。 
LinkedHashMap 是 HashMap 的 一 个 子 类 ， 如 果 需 要 输出 的 顺序 和 输入 的 相同 ， 那 么 可 以 用 
LinkedHashMap 实现 ， 它 还 可 以 按 读 取 顺序 来 排列 。 

四 、 附 加 题 

1. 答案 : 在 Java 语言 中 ， 默 认 使 用 Unicode 编码 方式 ， 即 每 个 字符 占用 两 个 字 节 ， 因 
此 ， 可 以 用 来 存储 中 文 。 虽 然 String 是 由 char 所 组 成 的 ， 但 是 它 采 用 了 一 种 更 加 灵活 的 方 
式 来 存储 ， 即 英文 占 个 字符 ， 中 文 占用 两 个 字符 ， 采 用 这 种 存储 方式 的 一 个 重要 作用 
就 是 可 以 减少 所 需 的 存储 空间 ， 提 高 存储 效率 。 根 据 这 个 特点 ， 可 以 采用 如 下 代码 来 完成 
题目 的 要 求 : 


public class Test 


{ 


// 判 断 字符 c 是 否 是 中 文字 符 ， 如 果 是 则 返回 tue 
public static boolean isChinese(char c) 


{ 


String sb = String.valueOf(c); 

return sb.getBytes().length > 1 ? true : false; 
} 
public String truncateStr(String str, int len) 


{ 
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if (str == null || str.equals("") || len == 0) 

return ""; 
char[] chrArr = str.toCharArray(); 
StringBuilder sb = new StringBuilder(""); 
int count = 0; /用 来 记录 当前 截取 字符 的 长 度 
for (char cc : chrArr) 


{ 
if (count < len) 
{ 
if (isChinese(cc)) 
{ 
/如 果 要 求 截取 子 串 的 长 度 只 差 一 个 字符 ， 但 是 接 下 来 的 字符 是 中 文 ， 
// 则 截取 结果 子 串 中 不 保存 这 个 中 文字 符 
if (count + 1 == len) 
return sb.toString(); 
count = count + 2; 
sb = Sb.append(cc); 
} 
else 
{ 
count = count+ 1; 
sb = Sb.append(cc); 
} 
} 
else 
break' 
} 
} 
return sb.toString(); 
} 
public static void main(String[] args) 
{ 
Test splitStr = new Test(); 
String sb=" 人 ABC 们 DEF"; 
System.out.println(splitStrtruncateStr(sb, 6)); 
} 
} 
程序 的 运行 结果 为 
人 ABC 


2. 答案 : 常见 的 排序 方法 有 选择 排序 、 插 入 排序 、 冒 泡 排序 、 归 并 排序 、 快 速 排序 、 和 希 
尔 排序 和 堆 排序 等 。 
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下 面 重点 介绍 插入 排序 。 对 于 给 定 的 一 组 记录 ， 初 始 时 假设 第 一 个 记录 自 成 一 个 有 序 序 
列 ， 其 余 的 记录 为 无 序 序列 。 接 着 从 第 二 个 记录 开始 ， 按 照 记 录 的 大 小 依次 将 当前 处 理 的 记 
录 搬 入 到 其 之 前 的 有 序 序列 中 ， 直 至 最 后 一 个 记录 插入 到 有 序 序列 中 为 止 。 以 数组 138，65， 
97，76，13，27，49} 为 例 ， 直 接 插入 排序 具体 步骤 如 下 所 示 : 

第 一 步 插 入 38 以 后 ， 序 列 为 : [38] 65 97 76 13 27 49 


第 二 步 插入 65 以 后 ， 序 列 为 : [38 65] 97 76 13 27 49 
第 三 步 插入 97 以 后 ， 序 列 为 : [38 65 97] 76 13 27 49 
第 四 步 插入 76 以 后 ， 序 列 为 : [38 65 76 97] 13 27 49 
第 五 步 插入 13 以 后 ， 序 列 为 : [13 38 65 76 97] 27 49 
第 六 步 插入 27 以 后 ， 序 列 为 : [13 27 38 65 76 97] 49 
第 七 步 插入 49 以 后 ， 序 列 为 : [13 27 38 49 65 76 97] 
程序 示例 如 下 : 
public class TestSort 
{ 
public static void insertSort(int[] a) 
if(a—null || a.length==0) 
return; 
for (inti= 1; i<a.length; i++) 
{ 
/把 a[i] 插 入 到 a[0~i-1] 的 有 序 子 列表 中 
int temp = ali], j= i; 
if (alj - 1] > temp) 
{ 
while Qj >= 1 && a[lj - 1] > temp) 
{ 
alj] = alj- 1]; 
j= 
} 
} 
alj] = temp; 
} 
} 
public static void main(String[] args) 
{ 
int[] array = { 7, 3, 19, 40, 4, 7, 1 }; 
insertSort(array); 
for (inti= 0; 1< array.length; 1++) 
System.out.print(array[i] + " "); 
} 
} 
程序 的 运行 结果 为 
134771940 
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ui 是 盈 某 知名 互联 网 金融 企业 软件 工程 师 笔 试题 


一 、 单 项 选择 题 


1. 答 


分 析 : 


案 : B。 


本 题 考 察 的 是 对 Java 运行 机 制 的 理解 。 


Java 语言 为 解释 性 语言 ， 运 行 的 过 程 如 下 : 源 代 码 经 过 Java 编译 器 编译 成 字 节 人 码 (Byte 


Code)， 然 


后 由 JVM (Java Virtual Machine，Java 虚拟 机 ) 解释 执行 。 而 C/C++ 语言 为 编译 型 


语言 ， 源 代码 经 过 编译 和 链接 后 生成 可 执行 的 二 进 制 代码 。 因 此 ，Java 语言 的 执行 速度 
比 C/C++ 语言 慢 ， 但 是 Java 语言 能 够 跨 乎 台 执行 ， 而 C/C++ 语 言 不 能 够 跨 平台 执行 。 


因此 ，Java 程序 经 编译 后 会 产生 Byte Code〈( 字 节 人 码 )， 选 项 B 正确 ， 而 选项 A、 选 项 C 
与 选项 DD 描述 都 不 正确 。 

所 以 ， 本 题 的 答案 为 了 B。 

2. 答案 : B。 


分 析 : 


本 题 考 察 的 是 对 Java 语言 来 历 的 理解 。 


对 于 选项 A，BASIC 语言 是 一 种 为 了 让 用 户 容易 控制 计算 机 开发 的 语言 ， 其 特点 是 简单 
易 懂 ， 且 可 以 用 解释 和 编译 两 种 方法 执行 。 

对 于 选项 B，C++ 语 言 是 一 种 静态 数据 类 型 检查 的 、 支 持 多 重 编程 范式 的 通用 程序 设计 
语言 ， 它 支持 过 程 化 程序 设计 、 数 据 抽 象 、 面 向 对 象 程序 设计 及 谤 型 程序 设计 等 多 种 程序 设 


计 风 格 。 


对 于 选项 C，Pascal 语言 是 为 提倡 结构 化 编程 而 发 明 的 语言 。 
对 于 选项 D，Ada 语言 是 美国 军 方 为 了 整合 不 同 语言 开发 的 系统 而 发 明 的 一 种 语言 ， 其 
最 大 的 特点 是 实时 性 ， 在 ADA95 中 已 加 入 面向 对 象 内 容 。 


Java 语言 是 一 种 面向 对 象 语言 ， 从 语法 结构 上 看 ， 与 C++ 语言 类 似 。 因 此 ， 选 项 B 正确 。 


所 以 ， 
3. 答 


分 析 : 


本 题 的 答案 为 B。 
案 : C。 


本 题 考察 的 是 对 构造 方法 的 理解 。 


构造 方法 是 一 种 特殊 的 方法 ， 它 与 类 同名 ， 并 且 没 有 返回 值 类 型 ， 其 目的 主要 是 完成 对 
象 的 初始 化 。 当 类 实例 化 一 个 对 象 时， 会 自动 调用 该 类 的 构造 方法 ， 需 要 注意 的 是 ， 构 造 方 


本 题 


法 和 其 他 方法 一 样 也 可 以 重 载 。 


PF， 对 于 选项 A， 类 中 的 构造 方法 是 可 以 省 略 的 ， 当 和 省略 的 时 候 ， 编 译 器 会 提供 一 


个 默认 的 无 参数 的 构造 方法 。 因 此 ， 选 项 A 错误 。 
对 于 选项 B， 由 于 构造 方法 也 可 以 重 载 ， 因 此 ， 一 个 类 可 以 定义 多 个 构造 方法 。 因 此 ， 
选项 B 错误 。 


对 于 选项 C， 当 一 个 对 象 被 new 的 时 候 必 定 会 调用 构造 方法 。 因 此 ， 选 项 C 正确 。 


对 于 选项 D， 构 造 方法 必须 与 类 名 相同 ， 但 是 方法 名 也 可 以 与 类 名 相同 。 如 下 例 所 示 : 


public class Test 


public Test() 
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System.out.println("construct ); 
} 
public void Test() 
{ 


System.out.println("call Test"); 


} 


public static void main(String[] args) 


{ 
Test a 二 new Test(); /调用 构造 方法 
a.Test(); /调用 Test 方法 
} 
程序 的 运行 结果 为 
construct 
call Test 


因此 ， 选 项 D 错误 。 

所 以 ， 本 题 的 答案 为 C。 

4. 答案 : A。 

分 析 : 本 题 考 察 的 是 对 Java 类 库 的 了 解 。 

包 (package) 是 Java 语言 提供 的 一 种 区 别 类 的 命名 空间 的 机 制 ， 它 是 类 的 组 织 方 式 ， 是 
一 组 相关 类 和 接口 的 集合 ， 提 供 了 访问 权限 和 命名 的 管理 机 制 。 

在 Java 语言 中 ， 包 的 作用 主要 体现 在 以 下 三 个 方面 : 

1) 方便 查找 与 使 用 。 将 功能 相近 的 类 放 在 同一 个 包 中 ， 可 以 方便 查找 与 使 用 。 

2) 避免 命名 冲突 。 由 于 在 不 同 包 中 可 以 存在 同名 类 ， 所 以 ， 使 用 包 的 好 处 是 在 一 定 程度 
上 可 以 避免 命名 冲突 。 

3) 访问 权限 设 定 。 某 次 访问 权限 是 以 包 为 单位 的 。 

本 题 中 ， 对 于 选项 A，java.sql 包 中 主要 包含 一 些 访问 数据 库 相 关 的 接口 。 所 以 ， 选 项 A 


正确 


对 于 选项 B，java.swing 是 一 个 用 于 开发 Java 应 用 程序 用 户 界面 的 开发 工具 包 。 所 以 ， 
选项 B 错误 。 

对 于 选项 C，java.io 提供 了 流 处 理 的 相关 接口 。 所 以 ， 选 项 C 错误 。 

对 于 选项 D，java.awt 包含 用 于 创建 用 户 界面 和 绘制 图 形 网 像 的 所 有 类 。 所 以 ， 选 项 D 
昔 误 。 

所 以 ， 本 题 的 答案 为 A。 

5. 答案 : A。 

分 析 : 本 题 考察 的 是 对 Java 运算 符 的 理解 。 

计算 机 的 最 基本 用 途 之 一 是 执行 数学 运算 ， 作 为 一 门 计算 机 语言 ，Java 也 提供 了 一 套 丰 
富 的 运算 符 来 操纵 变量 。 可 以 把 运算 符 分 成 以 下 几 组 : 算术 运算 符 (+、-、*、/、%、++、-- 


等 )、 关 系 运算 符 (= 二、!=、>、<、>=、<< 等 )、 位 运算 符 (&、|、^、~、<<、>>、>>> 等 )、 
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逻辑 运算 符 (&&、|、 


! 等 )、 赋 值 运 符 =、 上 -=、-=、+*=、/=、(0) =、<<=、>> =、&=-、| 


等 ) 及 其 他 运算 符 〈 条 件 运算 符 ?:、instanceof 运算 符 等 )。 
本 题 中 ,对 于 选项 A，&& 是 逻辑 操作 符 ，x&e&y 的 运算 逻辑 如 下 : 当 x 和 y 均 为 true 时 ， 


其 结果 是 true， 和 否则， 结果 是 false。 所 以 ， 选 项 A 正确 。 


对 于 选项 B， 一 不 是 Java 语言 的 运算 符 ， 其 作用 是 用 来 表示 泛 型 ， 例 如 ，List<String> 表 
示 这 个 列表 中 存放 的 是 String 类 型 的 变量 。 所 以 ， 选 项 B 不 正确 。 
对 于 选项 C，while 是 Java 语言 的 关键 字 ， 用 于 流程 控制 ， 它 不 是 运算 符 。 所 以 ， 选 项 C 


不 正 丰 


6. 答案 : C。 


对 于 选项 D，:= 不 是 Java 语言 的 运算 符 。 所 以 ， 选 项 D 不 正确 。 
所 以 ， 本 题 的 答案 为 A。 


分 析 : 本 题 考察 的 是 对 do while 循环 控制 语句 的 理解 。 
do while 循环 首先 会 执行 一 次 代码 块 , 然后 再 检查 循环 条 件 是 否 为 真 ， 如果 条 件 为 真 ， 就 
会 重复 这 个 循环 ， 和 否则 ， 结 束 循环 。 


对 于 本 题 而 言 ， 变 量 c 被 初始 化 为 0， 由 于 do while 循环 的 性 质 ， 此 时 会 首先 进入 循环 体 


执行 --c 运算 ， 运 算 完 之 后 ， 变 量 ec 的 值 变 为 -1， 然 后 执行 a=a-l 语句 ， 执 行 完 毕 后 ， 变 量 a 


的 值 变 为 -1， 紧 接着 


此 时 循环 结束 ，c 的 值 为 -1。 所 以 ， 选 项 C 正确 。 


> 


判断 变量 a 与 0 的 大 小 关系 ， 由 于 不 满足 a>0 这 一 循环 条 件 ， 所 以 ， 


所 以 ， 本 题 的 答案 为 C。 


7. 答案 : D。 


分 析 : 本 题 考察 的 是 对 Java 抽象 方法 的 理解 


抽象 方法 是 指 在 类 中 存在 没有 方法 体 的 方法 ， 在 Java 语言 中 ， 当 用 abstract 来 修饰 一 个 


方法 时 ， 该 方法 就 是 抽象 方法 。 由 此 可 见 ， 抽 象 方法 不 能 用 大 插 号 个 包 住 (一 旦 有 大 括号 就 


表明 这 个 方法 有 了 方法 体 )。 因 此 , 选项 D 正确 , 选项 B 和 选项 C 错误 。 对 于 选项 A, abstract 


只 能 修饰 类 和 方法 ， 不 能 修饰 字段 。 因 此 ， 选 项 A 错误 。 
所 以 ， 本 题 的 答案 为 D。 


8. 答案 : A。 


分 析 : 本 题 考察 的 是 对 形 参 和 实 参 的 理解 。 
形 参 全 称 为 “形式 参数 ” 是 在 定义 方法 名 和 方法 体 的 时 候 使 用 的 参数 ， 目 的 是 用 来 接收 


本 


用 该 方法 时 传递 的 参数 。 它 的 作用 范围 是 整个 方法 体 ， 是 在 方法 调用 时 的 一 个 临时 变量 。 
实 参 出 现在 主 调 方法 中 ， 在 方法 调用 的 时 候 把 实 参 的 值 赋 给 对 应 的 形 参 ， 在 被 调用 方法 的 内 


部 只 能 使 用 形 参 ， 不 能 使 用 实 参 。 


具体 而 言 ， 实 参 和 形 参 的 主要 区 别 如 下 : 


1) 形 参 的 作用 范围 为 方法 内 部 ， 当 方法 调用 结束 后 ,， 形 参 的 生命 周期 也 就 结束 了 , 因此 ， 
在 方法 外 不 能 使 用 形 参 ， 它 只 有 在 被 调用 时 才 分 配 内 存单 元 ， 调 用 结束 后 会 立刻 释放 内 存 空 
间 ， 而 实 参 不 能 在 调用 方法 的 内 部 使 用 。 

2) 在 方法 调用 的 时 候 ， 只 能 把 实 参 的 值 传送 给 形 参 ， 而 不 能 把 形 参 的 值 反 向 地 传送 给 实 


参 。 因 此 ， 在 方法 调用 过 程 中 ， 对 形 参 值 的 改变 不 会 影响 实 参 的 值 。 


如 下 例 所 示 : 
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public class Test 
public static void flint n) 
{ 
DT 十 ; 
System.out.printin(" 形 参 的 值 为 : "+n); 
} 
public static void main(String[] args) 
int n=1; 
fn); 
System.out.printn(" 实 参 的 值 为 : "+D); 
} 
} 
程序 的 运行 结果 为 
形 参 的 值 为 : 2 
实 参 的 值 为 : 1 


本 题 中 , 对 于 选项 A, 形 参 的 作用 范围 只 在 这 个 方法 内 ,因此 , 可 以 被 看 作 Local Variable 
(局 部 变量 )。 因 此 ， 选 项 A 正确 。 
对 于 选项 B， 形 参 可 以 是 原始 的 数据 类 型 (int、long 和 char) 等 ， 也 可 以 是 对 象 (String、 
List 或 自 定义 对 象 类 型 )。 因 此 ， 选 项 B 不 正确 。 

对 于 选项 C， 在 方法 调用 时 ， 真 正 被 传递 的 参数 为 实 参 。 因 此 ， 选 项 C 不 正确 。 

对 于 选项 D， 形 参 不 能 被 字段 修饰 符 修饰 (private、public 和 protected)。 因 此 ， 选 项 D 
不 正确 。 
所 以 ， 本 题 的 答案 为 A。 

9. 答案 : D。 

分 析 : 本 题 考 察 的 是 对 实例 方法 的 理解 。 

超 类 (Super Class) 也 叫 作 父 类 ， 在 Java 语言 中 ， 指 的 是 被 继承 的 类 ， 而 继承 的 类 称 为 
子 类 。 当 超 类 的 实例 方法 或 类 方法 为 private 的 时 候 ， 是 不 能 被 子 类 调用 的 。 同 理 ， 当 其 他 类 
的 实例 方法 为 private 的 时 候 ， 也 不 能 被 直接 调用 。 所 以 ， 选 项 D 正确 。 

所 以 ， 本 题 的 答案 为 D。 

10. 答案 ， D。 

分 析 : 本 题 考 察 的 是 对 Java 面向 对 象 概念 的 理解 。 

Java 语言 是 纯 面向 对 象 的 语言 ， 任 何 变 量 与 方法 都 必须 定义 在 类 中 ， 方 法 与 变量 不 能 胶 
离 类 的 定义 而 单独 存在 ， 因 此 ， 选 项 A 和 选项 B 错误 ， 选 项 D 正确 。 在 Java 语言 中 ， 方 法 
有 两 种 : 静态 方法 〈 类 的 方法 ) 与 非 静 态 方法 〈 实 例 的 方法 )， 因 此 ， 选 项 C 错误 ， 因 为 方法 
有 可 能 属于 实例 成 员 ， 而 不 属于 类 成 员 。 

所 以 ， 本 题 的 答案 为 D。 

二 、 多 项 选择 题 

1. 答案 A、C、D。 
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分 析 : 本 题 考 察 的 是 对 Java 编译 环境 的 理解 。 

本 题 中 ， 对 于 选项 A， 环 境 变量 在 编译 的 时 候 可 以 通过 java-classpath 来 指定 ， 因 此 ， 选 
项 A 正确 ， 选 项 B 错误 。 对 于 选项 C，javac *.java 就 可 以 编译 多 个 java 文件， 因此， 选项 C 正 
确 。 对 于 选项 D，javac.exe 有 个 -d 选项 来 指定 编译 结果 存放 的 目录 ， 因 此 ， 选 项 D 正确 。 

所 以 ， 本 题 的 答案 为 A、C、D。 

2. 答案 : A、C、D。 

分 析 : 本 题 考察 的 是 对 标识 符 命名 规则 的 理解 。 

对 于 选项 A, 站 是 Java 的 关键 字 ( 用 来 控制 程序 的 执行 流程 ;， 所 以 ， 它 不 能 作为 标识 符 
。 因 此 ， 选 项 A 错误 。 
对 于 选项 B， 以 $ 为 第 一 个 字符 ， 符 合 标识 符 要 求 。 因 此 ， 选 项 B 正确 。 

对 于 选项 C， 标 识 符 的 第 一 个 字符 不 能 数字 。 因 此 ， 选 项 C 错误 。 

对 于 选项 D， 标 识 符 中 不 能 有 点 号 “.”。 因 此 ， 选 项 DD 错误 。 

所 以 ， 本 题 的 答案 为 A、C、D。 

3. 答案 : B、C、D。 

分 析 : 本 题 考 察 的 是 对 Java 基本 类 型 的 理解 。 

在 Java 语言 中 ， 除 了 8 种 基本 数据 类 型 ， 其 他 的 类 型 都 是 对 象 ， 因 此 ， 选 项 A 正确 ， 选 
项 B 错误 。 选 项 C 的 写法 有 语法 错误 ， 正 确 的 写法 应 该 为 nt ar[={112,3,4}。 对 于 选项 D， 数 组 
的 大 小 是 在 定义 的 时 候 确 定 的 ， 一 旦 确定 后 就 不 能 任意 改变 了 ， 所 以 ， 选 项 D 错误 。 

所 以 ， 本 题 的 答案 为 B、C、D。 

4. 答案 : A、D。 

分 析 : 本 题 考 察 的 是 对 接口 的 理解 。 

在 Java 语言 中 ， 接 口 是 一 系列 方法 的 声明 ， 是 一 些 方法 特征 的 集合 ， 一 个 接口 具有 方法 
的 特征 ， 没 有 方法 的 实现 ， 因 此 ， 这 些 方法 可 以 在 不 同 的 地 方 被 不 同 的 类 实现 ， 而 这 些 实现 
可 以 具有 不 同 的 行为 〈 功 能 )。 接 口上 只 能 被 public 和 abstract 这 两 个 关键 字 修 饰 ， 而 不 能 被 
private、protected 和 static 修饰 。 所 以 ， 选 项 B 和 选项 C 正确 ， 选 项 A 与 选项 DD 错误 。 

所 以 ， 本 题 的 答案 为 A、D。 

5. 答案 : A、C、D。 

分 析 : 本 题 考察 的 是 对 值 传 递 与 引用 传递 的 理解 。 

按 值 传递 指 的 是 在 方法 调用 时 ， 传 递 的 参数 是 实 参 值 的 副本 。 按 引用 传递 指 的 是 在 方法 
调用 时 ， 传 递 的 参数 是 实 参 的 引用 ， 也 可 以 理解 为 实 参 所 对 应 的 内 存 空 间 的 地 址 。 

为 了 理解 Java 语言 中 的 值 传递 与 引用 传递 ， 首 先 给 出 下 面 的 示例 代码 ; 


public class Test{ 


>4 


Tt 


使 用 


public static void testPassParameter(StringBuffer ssl, int n) 


{ 
ssl.append(" World"); 
n=8; 
} 
public static void main(String[] args) 
{ 
int 1=1; 
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StringBuffer sl=new StringBuffer("Hello"); 
testPassParameter(s1,1); 
System.out.println(s1); 
System.out.printin(i); 


} 


程序 的 运行 结果 关 


Hello World 
1 


从 运行 结果 可 以 看 出 ，int 作为 参数 的 时 候 ， 对 形 参 值 的 修改 不 会 影响 到 实 参 ， 对 于 
StringBuffer 类 型 的 参数 ， 对 形 参 对 象 内 容 的 修改 影响 到 了 实 参 。 为 了 便于 理解 ，int 类 型 的 参 
数 可 以 理解 为 按 值 传递 ，StringBuffer 类 型 的 参数 可 以 理解 为 引用 传递 。 


为 了 便于 理解 ，Java 教科 书 中 经 常 提 到 在 Java 应 用 程序 中 永远 不 会 传递 对 象 ， 而 只 传 


递 对 象 引 用 ， 因 此 ， 是 按 引 用 传递 对 象 。 从 本 质 上 来 讲 ， 引 用 传递 还 是 通过 值 传递 来 实现 的 ， 
Java 语言 中 的 引用 传递 实际 上 还 是 值 传递 《传递 的 是 地 址 的 值 ) 如 图 9 所 示 。 
调用 前 传递 的 参数 


i OXFFFFF12 n 
sl | OX12345678 OX12345678 ssl 


调用 结果 调用 过 程 


[SR 
sl 0X12345678 Hello World OX12345678 ssl 


图 9 引用 传递 实例 


首先 按照 传统 的 分 析 方 法 来 理解 按 值 传 递 和 按 引 用 传递 : 

为 了 便于 理解 ,假设 1 和 “Hello” 存 储 的 地 址 分 别 为 0XFFFFFF12 和 0X12345678。 在 调用 
方法 testPassParameter 的 时 候 ， 由 于 i 为 基本 类 型 ， 因 此 ， 参 数 是 按 值 传递 的 ， 此 时 会 创建 
一 个 i 的 副本 ， 该 副本 与 1 有 相同 的 值 ， 把 这 个 副本 作为 参数 赋值 给 n， 作 为 传递 的 参数 。 
而 StringBuffer 由 于 是 一 个 类 ， 因 此 ， 按 引用 传递 ,传递 的 是 它 的 引用 (可 以 理解 为 传递 的 是 存 
储 “Hello” 的 地 址 )， 如 图 9 所 示 ， 在 testPassParameter 内 部 修改 的 是 n 的 值 ， 这 个 值 与 i 是 没 
关系 的 。 但 是 在 修改 ssl 的 时 候 ， 修 改 的 是 ssl 这 个 地 址 指向 的 字符 串 的 内 容 ， 由 于 形 参 ssl 与 
实 参 sl 指向 的 是 同一 块 存储 空间 ， 因 此 ， 修 改 ssl 后 ，sl 指向 的 字符 串 也 被 修改 了 。 

然后 从 另外 一 个 角度 来 对 引用 传递 进行 详细 分 析 : 

对 于 变量 sl 而 言 ， 它 是 一 个 字符 串 对 象 的 引用 ， 引 用 的 字符 串 的 值 是 “Hello”， 而 变量 
sl 的 值 为 0X12345678 〈 可 以 理解 为 是 “Hello” 的 地 址 ， 或 者 “Hello” 的 引用 )， 那 么 在 方法 
调用 的 时 候 ， 参 数 传递 的 其 实 就 是 s1 值 的 一 个 副本 (0X12345678)， 如 图 9 所 示 ，ssl 的 值 也 
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为 0X12345678。 如 果 在 方法 调用 的 过 程 中 通过 ss1 (字符 串 的 引 


内 容 ， 
是 方法 


或 地 址 ) 来 修改 字符 串 的 


因为 s1 与 ssl 指向 同一 个 字符 串 ， 所 以 通过 ssl 对 字符 串 的 修改 对 sl 也 是 可 见 的 。 但 


中 对 ssl 值 的 修改 对 sl 是 没有 影响 的 ， 如 下 例 所 示 : 
public class Test 
{ 
public static void testPassParameter(StringBuffer ss1) 
{ 
ssl = new StringBuffer("World"); 
} 
public static void main(String[] args) 
{ 
StringBuffer sl = new StringBuffer("Hello"); 
testPassParameter(s1); 
System.out.println(s1); 
} 


} 


程序 的 运行 结果 为 


Hello 


对 运行 结果 分 析 可 知 ， 在 testPassParameter 方法 中 ， 依 然 假 设 “Hello ”的 地 址 为 


0XFFFFFF12 (实际 J 


上 是 sl 的 值 ), 在 方法 调用 的 时 候 ， 首 先 把 sl 的 副本 传递 给 ss1， 此 时 ssl 


的 值 也 为 0XFFFFFF12, 通过 调用 ss1=new StringBuffer("World") 语 句 实际 上 是 改变 了 ssl 的 值 
(ssl 指向 了 男 外 一 个 字符 串 “World”)， 但 是 对 形 参 ssl 值 的 改变 对 实 参 s1 没有 影响 ， 虽 然 
ssl 被 改变 “World” 的 引用 (或 者 “World” 的 地 址 )，s1 还 是 代表 字符 串 “Hello” 的 引用 (或 
可 以 理解 为 sl 的 值 仍然 是 “Hello” 的 地 址 )。 从 这 个 角度 来 看 ，StringBuffer 从 本 质 上 来 讲 还 
是 值 传递 ， 它 是 通过 值 传递 的 方式 来 传递 引用 的 。 


对 于 本 题 ， 通 过 以 上 分 析 可 知 ， 值 传递 只 是 传递 了 一 个 值 的 副本 ， 对 形 参 值 的 改变 不 会 
影响 实 参 的 值 ， 因 此 ， 选 项 A 正确 。 参 数 的 地 址 也 是 以 值 的 方式 传递 ， 因 此 ， 无 法 改变 实 参 


的 地 址 ， 


所 以 ， 本 题 的 答案 为 A、C、D。 


6. 


答案 : A、C、D。 


分 析 : 本 题 考察 的 是 对 类 方法 和 实例 方法 的 理解 。 


对 于 选项 A， 在 Java 语言 


个 引用 上 


化 后 才 存 在 。 而 类 方法 是 被 static 修饰 的 方法 ， 是 不 依赖 于 对 象 而 存在 的 方法 。 所 以 ，this 只 


只 能 改变 实 参 地 址 所 指向 的 对 象 的 值 ， 因 此 ， 选 项 B 错误 ， 选 项 C 和 选项 DD 正确 。 


FP， 每 当 一 个 对 和 象 创建 后 ，Java 虚拟 机 都 会 给 这 个 对 象 分 配 一 
身 的 指针 ， 这 个 指针 的 名 字 就 是 this，this 是 对 当前 类 对 象 的 引用 ， 对 象 只 有 被 实例 


能 在 类 中 的 非 静 态 方法 中 使 用 ， 静 态 方法 和 静态 的 代码 块 中 绝对 不 


选项 A 错误 。 
对 于 选项 B， 显 然 ， 类 方法 可 以 直接 调用 类 方法 。 因 此 ， 选 项 B 正确 。 


对 于 选项 C， 类 方法 可 以 调用 任意 类 的 类 方法 ， 只 要 有 权限 访问 。 因 此 ， 选 项 C 错误 。 


能 出 现 this 的 用 法 。 因 此 ， 


对 于 选项 D， 从 实际 应 用 的 角度 出 发 ， 类 方法 是 属于 类 的 ， 所 有 对 象 公用 的 ， 而 实例 方法 
只 供 实例 化 的 对 象 来 使 用 ， 因 此 ， 类 方法 调用 实例 方法 是 没有 意义 上 
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static 修饰 的 类 方法 是 在 类 被 加 载 的 时 候 完成 的 ， 此 时 还 没有 任何 实例 化 对 象 被 初始 化 ， 实 例 的 
方法 还 不 存在 ， 因 此 ， 无 法 完成 调用 。 无 论 从 哪个 角度 出 发 考虑 ， 都 不 推荐 在 类 方法 中 调用 实 
例 方法 。 但 这 并 不 是 说 类 方法 绝对 不 能 调用 实例 方法 ， 如 果 有 对 和 象 被 实例 化 了 ， 在 这 种 情况 下 ， 
实例 化 的 对 象 就 存在 了 ， 此 时 通过 类 方法 调用 实例 化 的 方法 也 是 可 以 的 ， 如 下 例 所 示 : 


public class Test 
{ 
public static void main(String[] args) 
{ 
String a = "hello"; 
//print(a); // 没 有 实例 化 对 象 ， 编 译 错误 
Test t=new Test(); 
t.print(a); /有 实例 化 对 象 ， 可 以 执行 
} 
public void print(String str) 
{ 
System.out.println(str); 
} 
} 


因此 ， 选 项 D 错误 。 

所 以 ， 本 题 的 答案 为 A、C、D。 

7. 答案 : B、C、D。 

分 析 : 本 题 考 察 的 是 对 Java 基础 知识 的 理解 。 

对 于 选项 A, 在 Java 语言 中 , main 方法 是 程序 的 入 口 方 法 ,所 有 程序 的 执行 都 是 从 main 
方法 开始 的 ， 如 果 没 有 main 方法 ， 程 序 是 无 法 执行 的 。 所 以 ， 选 项 A 正确 。 

对 于 选项 B，J2SDK 是 Java 的 开发 环境 包 ， 它 包含 JDK 开 发 工具 包 ) 和 JRE (运行 时 
环境 包 )。 而 Java API 是 一 些 预先 定义 的 类 库 , 其 目的 是 提供 应 用 程序 与 开发 人 员 基 于 某 软 件 
或 硬件 的 以 访问 一 组 例 程 的 能 力 。 所 以 ， 选 项 B 错误 。 

对 于 选项 C 与 选项 D，Appletviewer 是 一 种 执行 HTML 文件 上 Java 小 程序 的 Java 浏览 
器 。 实 质 上 就 是 一 个 Applet 浏览 器 ，Applet 本 身 是 没有 main 方法 的 。 可 以 使 用 jdk 工具 里 
面 的 appletviewerexe 来 运行 Applet， 或 者 使 用 浏览 器 运行 ， 它 不 能 运行 jar 包 文 件 。 所 以 ， 
选项 C 和 选项 DD 错误 。 

所 以 ， 本 题 答案 为 B、C、D。 

三 、 判 断 题 

1. 答案 : 正确 。 

分 析 : Java 语言 采用 了 Unicode 编码 ， 一 个 Unicode 用 16bit( 合 2B) 来 表示 。 

2. 答案 : 正确 。 

分 析 : Java 程序 中 被 public 修饰 的 类 名 必须 与 文件 名 相同 。 

3. 答案 : 错误 。 

分 析 : 在 Java 语言 中 ， 有 很 多 数据 类 型 可 以 进行 转换 ， 但 是 也 有 部 分 无 法 转换 ， 例 如 int 
类 型 与 boolean 类 型 之 间 无 法 进行 转换 。 
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四 、 程 序 题 
1. 答案 :“hello”。 


分 析 : 本 题 中 ,在 调用 change 方法 时 ,传递 的 是 字符 串 a 的 引用 《或 地 址 )， 此 时 ，name 
与 a 指向 同一 个 字符 串 ， 也 就 是 说 ， 对 于 字符 串 a 的 地 址 而 言 ， 这 个 方法 调用 是 值 传递 ， 而 
在 方法 change 内 部 对 这 个 传递 的 地 址 〈 值 ) 进行 修改 ， 也 就 是 修改 了 name 的 指向 ， 这 个 修 


改 对 实 参 是 没有 影响 的 ， 因 此 ， 程 序 的 输出 结果 为 “hello”。 
2. 答案 : ABDCBDCB。 
分 析 : for 循环 语句 的 基本 结构 为 


for( 表 达 式 1; 表 达 式 2; 表 达 式 3) 


{ 
循环 体 
} 
它 的 执行 过 程 如 下 : 


1) 首先 执行 初始 化 语句 ， 表 达 式 1 (只 会 被 执行 一 次 )。 


2) 然后 执行 表达 式 2， 如 果 表 达 式 2 的 结果 为 false， 则 结束 循环 ， 否 则 ， 执 行 循环 体 ， 


然后 执行 表达 式 3。 

3) 循环 执行 步骤 2) ， 直 至 
循环 的 语句 (return 或 break) 。 

对 于 本 题 而 言 ， 执 行 步骤 如 下 : 

1) 首先 执行 fpo(A) 输 出 字符 'A'。 

2) 接着 执行 fpo(B) && (i < 2)， 输 出 字符 'B'， 且 这 个 表达 式 的 结果 为 true， 


i 


表达 式 2 的 结果 为 false 时 ， 退 出 循环 ， 或 者 循环 体内 有 退 


返回 值 为 false， 此 时 循环 结束 。 

因此 ， 程 序 的 输出 结果 为 ABDCBDCB。 
五 、 简 答题 

1. 答案 : 参见 真题 3 中 问答 题 5。 

2. 答案 : 以 下 将 分 别 对 & 与 &&& 进 行 说 明 。 


及 是 按 位 与 操作 符 , a&b 是 把 a 和 都 转换 成 二 进 制 数 后 ,然后 再 进行 按 位 与 的 运算 。 
及 有 & 为 迪 辑 与 操作 符 ，a&&b 就 是 当 且 仪 当 两 个 操作 数 均 为 tue 时 ， 其 结果 才 为 true， 只 要 有 


一 个 为 false，a&&b 的 结果 就 为 false。 


[a 
[| 


因此 ， 执 行 
循环 体 计 + 执行 后 i 的 值 变 为 1) ， 接 着 输出 字符 'D'， 然 后 执行 foo(C'")， 输 出 字符 'C'。 

3) 重复 第 2) 步 ， 由 于 此 时 i 的 值 为 1， 因 此 , 循环 条 件 为 tue， 接 着 会 输出 字符 'B'、'D'、 
'C'。 结 束 这 一 次 循环 后 ，i 的 值 变 为 2; 然后 继续 执行 循环 条 件 foo('B') && (i < 2)， 首 先 执行 
foo('B') 输 出 字符 'B'， 因 为 foo(B') 执 行 的 结果 为 ttue， 所 以 需要 继续 执行 判断 语句 i < 2， 显 然 


而 


此 外 ，&& 还 具有 短路 的 功能 ， 在 参与 运算 的 两 个 表达 式 中 ， 只 有 当 第 一 个 表达 式 的 返回 
值 为 true 时 ， 才 会 去 计算 第 二 个 表达 式 的 值 ， 如 果 第 一 个 表达 式 的 返回 值 为 false， 则 此 时 && 
运算 的 结果 就 为 false， 同 时 ， 不 会 去 计算 第 二 个 表达 式 的 值 。 例 如 ，ifil=0 && i++>10)， 当 
i 的 值 为 0 时 ， 表 达 式 il=0 的 返回 值 为 false， 因 此 ， 此 时 将 不 会 执行 第 二 个 表达 式 it+>10 的 


判断 。 
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3. 答案 : Collection 是 一 个 集合 接口 。 它 提供 了 对 集合 对 象 进行 基本 操作 的 通用 接口 方 
法 。 实 现 该 接口 的 类 主要 有 List 和 Set， 该 接口 的 设计 目标 是 为 各 种 具体 的 集合 提供 最 大 化 的 
统一 的 操作 方式 。 

Collections 是 针对 集合 类 的 一 个 包装 类 ， 它 提供 了 一 系列 静态 方法 实现 对 各 种 集合 的 搜 
索 、 排 序 以 及 线程 安全 化 等 操作 ， 其 中 的 大 多 数 方法 都 是 用 于 处 理 线性 表 。Collections 类 不 
能 实例 化 ， 如 同一 个 工具 类 ， 服 务 于 Collection 框架 。 如 果 在 使 用 Collections 类 的 方法 时 ， 对 
应 的 Collection 的 对 象 null， 则 这 些 方法 都 会 抛 出 NullPointerException 。 

下 例 为 Collections 使 用 的 例子 。 


import java.util.*; 
public class Test 
{ 
public static void main(String args[]) 
{ 
List<Integer> list = new LinkedList<Integer>(); 
int array[] = { 1, 7, 3, 2}; 
for (int i= 0;1< array.length; i++) 
{ 
list.add(new Integer(array[i])); 
} 
Collections. sort(list); 
for (int i= 0; 1< array.length; i++) 
{ 
System.out.println(list.get(D)); 
} 
} 
} 
程序 的 运行 结果 为 
1 
2 
3 
7 
4. 答案 : 参见 真题 1 中 简 答 题 1。 
5. 答案 : 参见 真题 3 中 问答 题 4。 


六 、 加 分 题 

1. 答案 : 设计 模式 (Design Pattern) 是 一 套 被 反复 使 用 、 多 数 人 知晓 的 、 经 过 分 类 编目 
的 、 代 码 设计 经 验 的 总 结 。 使 用 设计 模式 的 目的 是 为 了 代码 重用 ， 避 免 程 序 大 量 修改 ， 同 时 
使 代码 更 容易 被 他 人 理解 ， 并 且 保 证 代码 可 靠 性 。 显 然 ， 设 计 横 式 不 管 是 对 自己 还 是 对 他 人 
还 是 对 系统 都 是 有 益 的 ， 设 计 模 式 使 得 代码 编制 真正 地 工程 化 ， 设 计 模 式 可 以 说 是 软件 工程 
的 基石 。 

GoF (Gang ofFour) 23 种 经 典 设计 模式 见 表 7。 


151 


Java 程序 员 面试 笔试 真题 


表 7 GoF 23 种 经 典 设计 模式 

创 建 型 结 构 型 行 为 型 
Interpreter( 解 释 器 ) 
Template Method (模板 方法 ) 
Chain of Responsibility《〈 职 责 链 ) 
Command (命令 ) 
Iterator (迭代 器 ) 
Mediator (中 介 者 ) 
Memento〈 备 访 录 ) 
Observer〔 观 察 者 ) 
State 〈 状 态 ) 
Strategy《〈 策 略 ) 
Visitor〈 访 问 者 模式 ) 
常见 的 设计 模式 有 工厂 模式 (Factory Pattern)、 单 例 模式 (Singleton Pattern)、 适 配器 模式 
(Adapter Pattern)、 享 元 模式 (Flyweight Pattern 〉 以 及 观察 者 模式 (Observer Pattern ) 等 。 
工厂 模式 专门 负责 实例 化 有 大 量 公共 接口 的 类 。 工 厂 模式 可 以 动态 地 决定 将 哪 一 个 类 实 
例 化 ， 而 不 必 事 先知 道 每 次 要 实例 化 哪 一 个 类 。 客 户 类 和 工厂 类 是 分 开 的 。 消 费 者 无 论 什么 
时 候 需 要 某 种 产品 ， 需 要 做 的 只 是 向 工厂 提出 请 求 即 可 。 消 费 者 无 须 修改 就 可 以 接纳 新 产品 。 
当然 也 存在 缺点 ， 就 是 当 产 品 修改 时 ， 工 厂 类 也 要 做 相应 的 修改 。 

工厂 模式 包含 以 下 几 种 形态 ; 

1) 简单 工厂 〈Simple Factory) 模式 。 简 单 工厂 模式 的 工厂 类 是 根据 提供 给 它 的 参数 ， 返 
回 的 是 几 个 可 能 产品 中 的 一 个 类 的 实例 ， 通 常情 况 下 它 返 回 的 类 都 有 一 个 公共 的 父 类 和 公共 
的 方法 。 设 计 类 图 如 图 10 所 示 。 


Adapter_Class (适配器 类 ) 
Adapter_ Object〔 适 配器 对 象 ) 
Bridge (桥接 ) 

Composite (组 合 ) 

Decorator 〈 装 饰 ) 

Facade〔 外 观 ) 

Flyweight 〈 享 元 ) 

Proxy〔 代 理 ) 


Factory Method (工厂 方法 ) 
Abstract Factory (抽象 工厂 》 
Builder〈 生 成 器 ) 
Prototype (原型 ) 
Singleton 〈 单 例 ) 


Product SimpleFactory 


八 


ConcreteProduct 1 ConcreteProduct 2 


图 10 简单 工厂 模式 设计 类 图 


其 中 ，Product 为 待 实例 化 类 的 基 类 ， 它 可 以 有 多 个 子 类 ; SimpleFactory 类 中 提供 了 实例 


化 Product 的 方法 ， 这 个 方法 可 以 根据 传 入 的 参数 动态 地 创建 出 某 一 类 型 产品 的 对 象 。 

2) 工厂 方法 (Factory Method) 模式 。 工 厂 方法 模式 是 类 的 创建 模式 ， 其 用 意 是 定义 一 
个 用 于 创建 产品 对 象 的 工厂 的 接口 ， 而 将 实际 创建 工作 推迟 到 工厂 接口 的 子 类 中 。 它 属于 简 
单 工 厂 模 式 的 进一步 抽象 和 推广 。 多 态 的 使 用 ， 使 得 工厂 方法 模式 保持 了 简单 工厂 模式 的 优 
点 ， 而 且 克 服 了 它 的 缺点 。 设 计 类 图 如 图 11 所 示 。 

Product 为 产品 的 接口 或 基 类 ， 所 有 的 产品 都 实现 这 个 接口 或 抽象 类 《例如 
ConcreteProduct)， 这 样 就 可 以 在 运行 时 根据 需求 创建 对 应 的 产品 类 。Creator 实现 了 对 产品 所 
有 的 操作 方法 ， 而 不 实现 产品 对 象 的 实例 化 。 产 品 的 实例 化 由 Creator 的 子 类 来 完成 。 
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Creator 


| 
人 


八 


ConcreteProduct ConcreteCreator 


| eeateProduet0 | 
图 11 工厂 方法 模式 设计 类 图 


+createProductO 
+otherProductOpO 


3) 抽象 工厂 〈Abstract Factory) 模式 。 抽 象 工厂 模式 是 所 有 形态 的 工厂 模式 中 最 为 抽象 
和 最 具 一 般 性 的 一 种 形态 。 抽 象 工 三 模式 是 指 当 有 多 个 抽象 角色 时 使 用 的 一 种 工厂 模式 ， 抽 
象 工厂 模式 可 以 向 客户 端 提供 一 个 接口 ， 使 客户 端 在 不 必 指 定 产品 的 具体 的 情况 下 ， 创 建 多 
个 产品 族 中 的 产品 对 象 。 根 据 LSP 原则 〈 即 Liskov 蔡 换 原则 )， 任 何 接受 父 类 型 的 地 方 ， 都 
应 当 能 够 接受 子 类 型 。 因 此 ， 实 际 上 系统 所 需要 的 ， 仅 仅 是 类 型 与 这 些 抽 象 产品 角色 相同 的 
一 些 实例 ， 而 不 是 这 些 抽象 产品 的 实例 。 换 名 话说 ， 也 就 是 这 些 抽象 产品 的 具体 子 类 的 实例 。 
工厂 类 负责 创建 抽象 产品 的 具体 子 类 的 实例 。 设 计 类 图 如 图 12 所 示 。 


ConcreteProductA 2| 


佐 : 三 三 
1 
<<interface>> | ConcreteFactory 2 
AbstractProductA 1 | 


ConcreteProductA 1 


| 


ConcreteProductB 2 
ConcreteProductB 1 


图 12 抽象 工厂 模式 设计 类 图 


= 


AbstractProductB eh 


三 一 一 一 
1 
1 


+CreateProductA() 
CreateProductB() 


ConcreteFactory 1 


+CreateProductA() 
+CreateProductB() 


本 


1 

1 

| <<interface>> 
L AbstractFactory 


1 
1 
1 
1 
1 
A 


AbstractProductA 和 AbstractProductB 代表 一 个 产品 家 族 ， 实 现 这 些 接 口 的 类 代表 具体 的 


a 


的 所 有 类 型 的 产品 ， 它 的 


产品 。AbstractFactory 为 创建 产品 的 接口 ， 能 够 创建 这 个 产品 家 族 
子 类 可 以 根据 具体 情况 创建 对 应 的 产品 。 


2. 答案 : 以 下 将 分 别 对 Spring MVC、IoC 和 AOP 进行 解释 说 明 。 


(1) Spring MVC 


Spring MVC 是 在 Spring 框架 上 发 展 起 来 的 框架 , 它 提供 了 构建 Web 应 用 程序 的 全 功能 
MVC 模块 ， 使 用 了 Spring 可 插入 的 MVC 架构 ， 可 以 自由 地 选择 各 个 模块 所 使 用 的 架构 ， 
非常 灵活 。 例 如 可 以 选择 使 用 内 置 的 Spring Web 框架 ,也 可 以 选择 使 用 Struts 的 Web 框 
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架 。 通 过 策略 接口 , Spring 框架 是 高 度 可 配置 的 。 ET 例如 Java Server Pages 
(JSP) 技术 和 Velocity 模板 引擎 等 。 对 于 Spring MVC 框架 而 言 ， 它 并 不 知道 具体 使 用 了 哪 
个 视图 。Spring MVC 把 控制 器 、 模 型 、 分 派 器 以 及 处 理 程序 对 象 的 角色 进行 了 分 离 因此 ， 
Spring MVC 有 更 好 的 可 定制 性 。 


(2) IoC 
参见 真题 2 中 不 定 项 选择 题 16。 
(3) AOP 


AOP (Aspect-Oriented Programming， 面 向 切面 编程 ) 是 对 面向 对 象 开 发 的 一 种 补充 ， 它 
允许 开发 人 员 在 不 改变 原来 模型 的 基础 上 动态 地 修改 模型 从 而 满足 新 的 需求 。 例 如 ， 在 不 改 
变 原 来 业务 逻辑 模型 的 基础 上 ， 可 以 动态 地 增加 日 志 、 安 全 或 异常 处 理 的 功能 。 

下 面 介绍 一 个 在 Spring 中 使 用 AOP 编程 的 简单 例子 

1) 创建 一 个 接口 以 及 实现 这 个 接口 的 类 。TestAOPIn.java 内 容 如 下 所 示 : 


public interface TestAOPIn{ 
public void doSomething(); 


} 
TestAOPImpl.java 内 容 如 下 所 示 : 


public class TestAOPImpl implements TestAOPIn{ 
public void doSomething(){ 
System.out.println("TestAOPImpl:doSomething"); 


} 
2) 配置 SpringConfig.xml， 使 


导 这 个 类 的 实例 化 对 象 可 以 被 注入 到 使 用 这 个 对 象 的 Test 


o 


<?xml version="1.0" encoding="UTF-8"?> 

<IDOCTYPE beans PUBLIC "-/SPRING/DTD BEAN/EN" "http://www.springframework.org/ 
dtd/spring-beans.dtd"> 

<beans> 

<bean id="testAOPBean" class="org.springframework.aop.framework.ProxyFactoryBean"> 

<property name= target > 

<bean class=”testAOPIn” singleton="false” /> 

</property> 

</bean> 


</beans> 


3) 在 完成 配置 文件 后 ， 编 写 测试 代码 如 下 所 示 : 


import org.springframework.context.ApplicationContext; 
import org.springframework.context.support.FileSystemXmlApplicationContext; 
public class Test { 
public static void main(String[] args) { 
ApplicationContext ctx = new FileSystemXmlApplicationContext("Spring 


Config.xml "); 
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TestAOPIn t= (TestAOPIn)ctx.getBean("testAOPBean"); 
t.doSomething(); 
} 
TestAOPImpl:doSomething 
当 编 号 完 这 个 模块 后 ， 开 发 人 员 需 要 增加 对 doSomething() 方 法 调用 的 跟踪 ， 也 就 是 说 ， 
要 跟踪 该 方法 ， 了 解 该 方法 什么 时 候 被 调用 以 及 什么 时 候 调用 结束 等 内 容 。 当 然 ， 使 用 传统 
的 方法 也 可 以 实现 该 功能 ， 但 是 会 产生 额外 的 开销 ， 即 需要 修改 已 存在 的 模块 。 所 以 ， 可 以 
采用 如 下 的 方式 来 实现 这 个 功能 : 


public class TestAOPImpl implements TestAOPIn{ 
public void doSomething(){ 


System.out.println("beginCall doSomething"); 
System.out.println("TestAOPImpl:doSomething"); 
System.out.println("endCall doSomething"); 


} 


此 时 可 以 采用 AOP 的 方式 来 完成 ， 它 在 不 修改 原 有 模块 的 前 提 下 可 以 完成 相同 的 功能 。 
实现 原理 如 图 13 所 示 。 


人 
1 
I getBean 1 | 
Inew TestAOPImpl0| 
1 
beforeCall 


doSomething 


afterCall 


[ere 


一 


图 13 AOP 方式 实现 原理 
为 此 需要 提供 用 来 跟踪 方法 调用 的 类 ，traceBeforeCall.java 文件 内 容 如 下 所 示 : 


public class traceBeforeCall implements MethodBeforeAdvice { 
public void beforeCall (Method arg0, Object[] arg1, Object arg2) throws Throwable { 
System.out.println("beginCall doSomething "); 


} 
traceEndCall.java 文件 内 容 如 下 所 示 : 
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import java.lang.reflect.Method; 
import org.Springframework.aop.AfterReturningAdvice; 
public class traceEndCall implements AfterReturningAdvice { 
public void afterCall(Object arg0, Method argl, Object[] arg2, Object arg3) throws Throwable { 
System.out.println("endCall doSomething); 


= 一 


只 需要 在 配置 文件 中 配置 在 调用 doSomething(0) 方 法 之 前 需要 调用 traceBeforeCall 类 的 
beforeCall0 方 法 ， 在 调用 doSomething0 方 法 之 后 需要 调用 traceEndCall 类 的 afterCall0 方 法 ， 
Spring 容器 就 会 根据 配置 文件 在 调用 doSomething0 方 法 前 后 自动 调用 相应 的 方法 ， 通 过 在 
beforeCall0 方 法 和 afterCall0) 方 法 中 添加 跟踪 的 代码 , 就 可 以 满足 对 doSomething() 方 法 调用 的 
跟 踊 要 求 ， 同 时 还 不 需要 更 改 原来 已 实现 的 代码 模块 。 


5 引言: 放 、 菏 知名 搜索 引擎 提供 商 软 件 工 程 师 笔试 题 


一 、 单 选 题 

1. 管 案 : D。 

分 析 : 本 题 考察 的 是 Java 语言 中 访问 修饰 符 知 识 。 

实例 方法 也 叫 作 对 象 方法 ， 它 与 类 方法 不 一 样 ， 类 方法 通常 由 关键 字 static 修饰 ， 属 于 整 
个 类 ， 而 实例 方法 是 属于 类 的 某 个 对 象 的 。 由 于 类 方法 是 属于 整个 类 的 ， 它 并 不 属于 类 的 哪 
个 对 象 ， 所 以 ， 类 方法 的 方法 体 中 不 能 有 与 类 的 对 象 有 关 的 内 容 ， 而 实例 方法 几乎 没有 什么 
限制 : 旬 实 例 方法 中 可 以 引用 对 象 变量 ， 也 可 以 引用 类 变量 ;外 实例 方法 中 可 以 调用 类 方法 ; 
他 实例 方法 中 可 以 使 用 关键 字 super 与 this。 

对 于 选项 A， 继 承 是 面向 对 象 的 特性 之 一 ， 在 继承 中 ， 子 类 只 能 访问 父 类 〈 超 类 ) 的 被 
public 与 protected 修饰 的 方法 ， 而 不 能 访问 其 private 方法 。 所 以 ， 子 类 是 否 可 以 调用 父 类 的 
方法 ， 需 要 看 父 类 的 方法 的 访问 权限 ， 所 以 ， 实 例 方 法 可 以 直接 调用 超 类 的 类 方法 的 描述 是 
背 误 的 。 因 此 ， 选 项 A 错误 。 

对 于 选项 B， 如 果 超 类 的 实例 方法 没有 在 子 类 中 被 重 写 ， 就 可 以 直接 调用 ， 但 如 果 经 过 子 
类 重 写 了 ， 则 就 被 覆盖 了 ， 此 时 就 需要 通过 关键 字 super 来 调用 。 因 此 ， 选 项 B 错误 。 

对 于 选项 C， 实 例 方 法 只 能 访问 其 他 类 实例 方法 中 被 public 修饰 的 方法 ， 而 不 能 访问 被 
protected 和 private 修饰 的 方法 。 因 此 ， 选 项 C 错误 。 

对 于 选项 D， 实 例 方 法 当然 可 以 访问 本 类 的 所 有 方法 。 因 此 ， 选 项 DD 正确 。 

所 以 ， 本 题 的 答案 为 D。 

2. 答案 : D。 

分 析 : 本 题 考 察 的 是 Java 抽象 方法 知识 。 

在 Java 语言 中 ， 抽 象 方法 指 的 是 类 中 没有 方法 体 的 方法 ， 而 含有 抽象 方法 的 类 就 叫 抽象 
类 。 如 果 一 个 子 类 没有 实现 父 类 中 的 抽象 方法 ， 则 子 类 也 成 为 一 个 抽象 类 。 

本 题 中 ， 对 于 选项 A， 抽 象 方法 是 没有 方法 体 body) 的 方法 ， 因 此 ， 没 有 大 括号 。 所 
以 ， 选 项 A 错误 。 
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对 于 选项 B，abstract 只 能 用 来 修饰 方法 和 类 ， 不 能 修饰 字段 。 所 以 ， 选 项 B 错误 。 

对 于 选项 C， 抽 象 方法 是 没有 方法 体 (body) 的 方法 ， 因 此 ， 没 有 大 括号 ， 一旦 有 了 大 
括号 就 表明 这 个 方法 有 方法 体 ， 此 时 就 不 是 抽象 方法 。 所 以 ， 选 项 C 错误 。 

对 于 选项 D， 从 上 面 分 析 可 以 看 出 ， 选 项 D 正确 。 

所 以 ， 本 题 的 答案 为 D。 

3. 答案 : D。 

分 析 : 本 题 考 察 的 是 Java 语言 中 的 static 知识 。 

在 Java 语言 中 ， 方 法 名 称 、 成 员 变 量 都 可 以 用 关键 字 static 修饰 ， 但 是 局 部 变量 不 能 有 
static 修饰 ， 也 就 是 说 ， 方 法 体 中 的 变量 是 不 能 被 static 修饰 的 。 本 题 中 ,将 局 部 变量 i 定义 为 
static, 因此 , 上述 程 序 会 报 编译 错误 。 正 确 的 做 法 是 把 static inti= 0 改 成 inti= 0, 或 者 把 static 
inti= 0 定义 为 成 员 变 量 。 所 以 ， 选 项 D 正确 。 

所 以 ， 本 题 的 答案 为 D。 

4. 答案 : D。 

分 析 : 本 题 考 察 的 是 继承 与 多 态 知识 。 

如 果 有 两 个 方法 的 方法 名 相同 ， 但 参数 不 一 致 ， 那 么 一 个 方法 是 另 一 个 方法 的 重 载 。 如 
果 在 子 类 中 定义 了 一 个 方法 ， 其 方法 名 称 、 返 回 值 类 型 及 参数 列表 正好 与 父 类 中 某 个 方法 的 
名 称 、 返 回 值 类 型 及 参数 列表 一 致 ， 那 么 ， 此 时 子 类 的 方法 覆盖 了 父 类 的 方法 。 

本 题 是 典型 的 方法 override〈 履 盖 )， 它 要 求 子 类 中 的 方法 必须 与 父 类 完全 相同 〈 相 同 的 
方法 名 、 相 同 的 参数 列表 及 相同 的 返回 值 )。 

对 于 本 题 而 言 ， 父 类 中 定义 了 一 个 getLenght 方法 ， 子 类 中 也 有 同样 的 方法 ， 但 是 却 有 着 
不 同 的 返回 值 ， 因 此 ， 编 译 错 误 。 所 以 ， 选 项 D 正确 。 

所 以 ， 本 题 的 答案 为 D。 

5. 答案 : C。 

分 析 : 本 题 考察 的 是 Servlet 工作 方式 。 

Servlet 是 采用 Java 语言 编写 的 服务 器 端 程序 , 它 运 行 于 Web 服务 器 中 的 Servlet 容器 中 ， 
其 主要 功能 是 提供 请 求 /响应 的 Web 服务 模式 ， 可 以 生成 动态 的 Web 内 容 ，Servlet 工作 原理 
如 图 14 所 示 。 

Servlet 处 理 客户 端 请 求 通常 有 如 下 几 个 步 又; 

1) 用 户 通过 单 击 一 个 链接 来 向 Servlet 发 起 请 求 。 

2) Web 服务 器 接收 到 该 请 求 后 ， 会 把 该 请 求 提交 给 相应 的 容器 来 处 理 ， 当 容器 发 现 
这 是 对 Servlet 发 起 的 请 求 后 ， 容 器 此 时 会 创建 两 个 对 象 ; HttpServletResponse 和 Http 
ServletRequest。 

3) 容器 可 以 根据 请 求 消息 中 的 URL 消息 找到 对 应 的 Servlet， 然 后 针对 该 请 求 创建 一 个 
单独 的 线程 ， 同 时 把 第 2) 步 中 创建 的 两 个 对 象 以 参数 的 形式 传递 到 新 创建 的 线程 中 。 

4) 容器 调用 Servlet 的 service0 方 法 来 完成 对 用 户 请 求 的 响应 ，service(0) 方 法 会 调用 
doPost( 方 法 或 doGet() 方 法 来 完成 具体 的 响应 任务 ， 同 时 把 生成 的 动态 页 面 返回 给 容器 。 

5) 容器 把 响应 消息 组 装 成 HITP 格式 返回 给 客户 端 。 此 时 ， 这 个 线程 运行 结束 ， 同 时 删 
除 第 2) 步 创 建 的 两 个 对 象 HttpServletResponse 和 HttpServletRequest。 
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上 Request 
一 一 1. Http 请 求 a 
一 一 1. Http 响 应 


调用 service0: 、 
调用 doGetO0 4. 处 理 请 求 


3. 传递 参数 


或 doPost() 


图 14 Servlet 工作 原理 


容器 会 针对 每 次 请 求 创建 一 个 新 的 线程 进行 处 理 ， 同 时 ， 会 针对 每 次 请 求 创 建 
HttpServletResponse 和 HttpServletRequest 两 个 对 象 ， 人 处理 完成 后 ， 线 程 也 就 退出 了 。 所 以 ， 
选项 C 正确 。 

所 以 ， 本 题 的 答案 为 C。 

6. 答案 : B。 

分 析 : 本 题 考察 的 是 JDBC 的 知识 。 

JDBC (Java DataBase Connectivity，Java 数据 库 连 接 ) 用 于 在 Java 程序 中 实现 数据 库 操 
作 功 能 ， 它 提供 了 执行 SQL 语句 、 访 问 各 种 数据 库 的 方法 ， 并 为 各 种 不 同 的 数据 库 提供 统一 
的 操作 接口 ，java.sql 包 中 包含 了 JDBC 操作 数据 库 的 所 有 类 。 通 过 JDBC 访问 数据 库 一 般 有 
如 下 几 个 步骤 : 

1) 加载 JDBC 驱动 器 。 将 数据 库 的 JDBC 驱动 加 载 到 classpath 中 ， 在 基于 Java EE 的 
Web 应 用 开发 过 程 中 ， 通 常 要 把 目标 数据 库 产品 的 JDBC 驱动 复制 到 WEB-INF/lib 下 。 

2) 加 载 JDBC 驱动 , 并 将 其 注册 到 DriverManager 中 ,一 般 使 用 反射 Class.forName(String 
driveName)。 

3) 建立 数据 库 连 接 ， 取 得 Connection 对 象 。 一 般 通 过 DriverManager.getConnection(url， 
username，passwd) 方 式 实现 ， 其 中 ，url 表示 连接 数据 库 的 字符 串 ，username 表示 连接 数据 库 
的 用 户 名 ，passwd 表示 连接 数据 库 的 密码 。 

4) 建立 Statement 对 象 或 者 PreparedStatement 对 象 。 

5) 通过 Statement 或 PreparedStatement 对 象 执行 SQL 语句 。 

6) 访问 结果 集 ResultSet 对 象 。 

7) 依次 将 ResultSet、Statement、PreparedStatement 和 Connection 等 对 象 关 闭 ， 释 放 掉 所 
占用 的 资源 。 

通过 上 述 分 析 可 知 ， 选 项 B 正确 。 

所 以 ， 本 题 的 答案 为 B。 

7. 答案 : C。 

分 析 : 本 题 考察 的 是 JDBC 的 知识 。 

存储 过 程 (Stored Procedure) 是 在 大 型 数据 库 系统 中 ， 一 组 为 了 完成 特定 功能 的 SQL 语 
集 ， 存 储 在 数据 库 中 经 过 第 一 次 编译 后 再 次 调用 时 不 需要 再 次 编译 ， 用 户 通过 指定 存储 过 


可 
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程 的 名 字 并 给 出 参数 〈 如 果 该 存储 过 程 带 有 参数 ) 来 执行 它 。 存 储 过 程 是 数据 库 中 的 一 个 重 
要 对 象 ， 任 何 一 个 设计 良好 的 数据 库 应 用 程序 都 应 该 用 到 存储 过 程 。 

本 题 中 ,对 于 选项 A，DriverManager 是 JDBC 的 管理 层 , 它 作 用 于 用 户 和 驱动 程序 之 问 ， 
管理 一 组 JDBC 驱动 程序 的 基本 服务 ， 提 供用 来 建立 数据 库 连 接 的 一 系列 方法 。 除 此 以 外 ， 
DriverManager 还 处 理 诸如 驱动 程序 登录 时 间 限 制 以 及 登录 与 跟踪 消息 的 显示 等 事务 。 因 此 ， 
选项 A 错误 。 

对 于 选项 B，ResultSet 表示 查询 的 结果 集 ， 通 常 通过 执行 查询 数据 库 的 语句 生成 。 
ResultSet 对 象 具 有 指向 其 当前 数据 行 的 光标 。 最 初 ， 光 标 被 置 于 第 一 行 之 前 ，next 方法 将 光 
标 移动 到 下 一 行 , 因为 该 方法 在 ResultSet 对 象 没有 下 一 行 时 返回 false, 所 以 , 可 以 在 while 循 
环 中 使 用 它 来 迭代 结果 集 。 因 此 ， 选 项 B 错误 。 

对 于 选项 C，CallableStatement 提供 了 用 来 调用 数据 库 中 存储 过 程 的 接口 ， 如 果 有 输出 
参数 要 注册 ， 说 明 是 输出 参数 。 因 此 ， 选 项 C 正确 。 

对 于 选项 D，PreparedStatement 表示 预 编译 的 SQL 语句 的 对 象 ,， 用 于 执行 带 参数 的 预 编 
译 SQL 语句 。 因 此 ， 选 项 D 错误 。 

所 以 ， 本 题 的 答案 为 C。 

8. 答案 : D。 

分 析 : 本 题 考察 的 是 Java 垃圾 回收 知识 。 

在 Java 语言 中 , 当 没 有 对 和 象 引 用 指向 原先 分 配给 某 个 对 和 象 的 内 存 时, 该 内 存 便 成 为 垃圾 。 
Java 虚拟 机 的 一 个 系统 级 线程 会 自动 释放 该 内 存 块 。 当 一 个 对 象 不 再 被 引用 时 ， 内 存 回 收 它 
占领 的 空间 ， 以 便 空 间 被 后 来 的 新 对 象 使 用 ， 不 仅 如 此 ， 垃 圾 回收 除了 释放 没 用 的 对 象 ， 也 
可 以 清除 内 存 记 录 碎 片 。 

本 题 中 ， 对 于 选项 A，finalize 方法 是 在 对 象 空间 被 回收 前 调用 的 。 所 以 ， 选 项 A 错误 。 

对 于 选项 B， 成 为 垃圾 的 对 象 ， 只 有 在 下 次 垃圾 回收 器 运行 的 时 候 才 会 被 回收 ， 而 不 是 
马上 被 清理 。 所 以 ， 选 项 B 错误 。 

对 于 选项 C， 在 C++ 语言 中 ， 调 用 了 析 构 函数 后 ， 对 象 一 定 会 被 销毁 ， 而 Java 语言 调用 
了 finalize 方法 , 垃圾 却 不 一 定 会 被 回收 ， 因 此 ，finalize 方法 与 C++ 语言 的 析 构 函 数 是 不 同 的 
概念 。 所 以 ， 选 项 C 错误 。 

对 于 选项 D， 当 一 个 对 象 不 再 被 引用 后 就 成 为 垃圾 ， 而 垃圾 是 可 以 被 回收 的 ， 但 是 线程 
就 算 没有 被 引用 也 可 以 独立 运行 ， 因 此 ， 它 与 对 象 不 同 。 所 以 ， 选 项 D 正确 。 

所 以 ， 本 题 的 答案 为 D。 

9. 答案 : B。 

分 析 : 本 题 考 察 的 是 MVC 设计 模式 。 

使 用 JSP 与 Servlet 实现 的 MVC 模型 如 图 15 所 示 。 

在 这 个 MVC 模型 中 ， 视 图 模块 采用 JSP 来 实现 ， 主 要 负责 数据 的 展现 ， 视 图 可 以 从 控 
制 器 上 获取 模型 的 状态 ， 当 然 不 是 直接 从 控制 器 上 获取 到 的 ， 而 是 控制 器 把 模型 的 数据 放 到 
一 个 视图 可 以 访问 的 地 方 ， 通 过 这 种 间接 的 方式 来 访问 模型 的 数据 。 

控制 器 使 用 Servlet 来 实现 ， 客 户 端 的 所 有 请 求 都 发 送 给 Servlet， 它 接受 请 求 ， 并 
根据 请 求 消息 把 它们 分 发 给 对 应 的 JSP 页 面 来 响应 ， 同 时 根据 需求 生成 JavaBean 实例 
供 JSP 来 使 用 。 


[hill 


l 
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Java 程序 员 面 试 笔试 真题 库 


控制 器 
Servlet 实现 


模型 
采用 JavaBean 实 现 


视图 
采用 JSP 实 现 


图 15 MVC 模型 


模型 采用 JavaBean 来 实现 的 ， 这 个 模块 实现 了 实际 的 业务 逻辑 。 


从 以 上 分 析 可 知 ， 选 项 B 正确 。 


所 以 ， 本 题 的 答案 为 B。 


10. 答案 : C。 


分 析 : 本 题 考 察 的 是 Java 垃圾 回收 知识 。 


在 Java 语言 中 ， 


GC 〈Garbage Collection， 垃 圾 回收 ) 是 一 个 非常 重要 的 概念 ， 它 的 主要 


作用 是 回收 程序 中 不 再 使 用 的 内 存 。 在 使 用 C/C++ 语 言 进行 程序 开发 的 时 候 ， 开 发 人 员 必 须 
非常 仔细 地 管理 好 内 存 的 分 配 与 释放 ， 如 果 忘 记 或 者 错误 地 释放 内 存 往往 会 导致 程序 运行 不 


正确 甚至 是 程序 的 骨 泪 。 为 了 减轻 开发 人 员 的 工作 ， 同 时 增加 系统 的 安全 性 与 稳定 性 ，Java 


0H 


语言 提供 了 垃圾 回收 器 来 自动 检测 对 象 的 作用 域 ， 实 现 上 自动 地 把 不 再 被 使 用 的 存储 空间 释放 


掉 。 具 体 而 言 ， 垃 圾 回收 器 要 负责 完成 3 项 任务 : 分 配 内 存 、 确 保 被 引用 对 象 的 内 存 不 被 错 


误 地 回收 以 及 回收 不 再 被 引用 的 对 象 的 内 存 空 间 。 


垃圾 回收 器 的 存在 ， 一 方面 把 开发 人 员 从 释放 内 存 的 复杂 的 工作 中 解脱 出 来 ， 提 高 了 开 


发 人 员 的 生产 效率 ; 


另外 一 方面 ， 对 开发 人 员 屏 项 了 释放 内 存 的 方法 ， 可 以 避免 因为 开发 人 


员 错 误 地 操作 内 存 从 而 导致 应 用 程序 的 崩溃 ， 保 证 了 程序 的 稳定 性 。 但 是 ， 垃 圾 回收 也 带 来 
了 问题 ， 为 了 实现 垃圾 回收 ， 垃 圾 回收 器 必须 跟踪 内 存 的 使 用 情况 ， 释 放 没 用 的 对 象 ， 在 完 


成 内 存 的 释放 后 还 需要 处 理 堆 中 的 碎片 ， 这 些 操 作 必 定 会 增加 JVM 的 负担 ， 从 而 降低 程序 的 


执行 效率 。 
对 于 对 象 而 言 ， 


如 果 没 有 任何 变量 去 引用 它 ， 那 么 该 对 象 将 不 可 能 被 程序 访问 ， 因 此 ， 
只 


可 以 认为 它 是 垃圾 信息 ， 可 以 被 回收 。 只 要 有 一 个 以 上 的 变量 引用 该 对 象 ， 该 对 象 就 不 会 被 


垃圾 回收 。 


对 于 本 题 而 言 ， 


首先 ， 在 第 11 行 定 义 了 一 个 Float 对 象 o， 接 着 ， 在 第 13 行 把 这 个 对 象 


的 引用 赋值 给 数组 oa[0] 的 第 一 个 元 素 ， 此 时 这 个 Float 对 象 有 两 处 被 引用 的 地 方 ， 分 别 为 o 
和 oaf0]; 在 第 14 行 中 执行 o = null 后 ， 这 个 Float 对 象 仍 然 被 oaf0] 引 用 ， 在 执行 完 第 15 行 
后 这 个 Float 对 象 没 有 被 任何 变量 引用 了 ， 因 此 ， 就 具备 了 被 垃圾 回收 器 回收 的 条 件 。 所 以 ， 


选项 C 正确 。 


所 以 ， 本 题 的 答案 为 C。 


11. 答案 : B。 


分 析 : 本 题 考察 的 是 构造 方法 在 继承 情况 下 的 调用 。 


构造 方法 是 一 利 
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特殊 的 方法 ， 用 来 在 对 象 实例 化 时 初始 化 对 象 的 成 员 变 量 。 在 Java 语言 


中 ， 构 造 方法 具有 以 下 特点 : 


1) 子 类 可 以 通过 关键 字 super 来 显 式 地 调 月 


构造 方法 时 ， 子 类 的 构造 方法 中 必须 显 式 地 调 月 


真题 详解 篇 


昌 父 类 的 构造 方法 ， 当 父 类 没有 提供 无 参数 的 
昌 父 类 的 构造 方法 ， 如 果 父 类 中 提供 了 无 参数 


的 构造 方法 ， 此 时 子 类 的 构造 方法 就 可 以 不 显 式 地 调用 父 类 的 构造 方法 ， 在 这 种 情况 下 ， 编 


译 器 会 默认 调用 父 类 的 无 参数 的 构造 方法 。 
类 的 构造 方法 ， 然 后 才 执 行 子 类 的 构造 方法 。 


当 有 父 类 存在 ， 在 实例 化 对 象 时 ， 会 


先 执行 父 


2) 当 父 类 和 子 类 都 没有 定义 构造 方法 时 ， 编 译 器 会 为 父 类 生成 一 个 默认 的 无 参数 的 构造 


方法 ， 给 子 类 也 生成 一 个 默认 的 无 参数 的 构造 方法 。 
在 本 题 中 , 当 调 用 new Alpha0 的 时 候 , 会 首先 调 月 
然后 调用 Alpha 类 的 构造 方法 〈 编 


所 以 ， 本 题 的 答案 为 B。 


12. 答案 : A。 


分 析 : 本 题 考 察 的 是 对 J2EE 的 理解 。 
J2EE (Java2 Platform Enterprise Edition) 是 Java 平台 企业 版 的 简称 ， 是 用 来 开发 与 部 署 


企业 级 应 用 的 一 个 架构 ， 它 提供 了 一 种 统一 的 、 了 


服务 和 通信 三 个 模块 构成 。 


构件 包含 客户 端 构件 和 服务 端 构件 两 种 类 型 ， 其 中 客户 端 构件 主要 包含 两 类 : Applets 和 


于 放 标 准 的 多 层 平台 ， 该 平台 主要 由 构件 、 


昌 父 类 的 无 参数 的 构造 方法 , 输出 Base， 
译 器 提供 了 一 个 默认 的 构造 方法 ) ， 接 着 在 调 月 
的 时 候 ， 也 会 调用 Base 类 的 构造 方法 ， 输 出 Base。 所 以 ， 选 项 B 正确 。 


H new Base() 


Application Clients， 服 务 端 构件 分 为 两 类 : Web 构件 (Servlet 与 JSP) 和 EJBs (Enterprise Java 


Beans )。 服 务 由 J2EE 平台 提供 商 实 现 ， 分 为 Service API (开发 时 使 月 


是 由 容器 提供 的 支持 协作 构件 之 间 的 通信 。 


从 本 质 上 来 讲 , J2EE 只 是 一 个 行 刘 


标准 ， 主 要 为 通过 Java 技术 帮 


F 发 服务 端 应 用 提供 一 个 


目 ) 和 运行 时 服务 。 通 信 


独立 的 、 可 移植 的 以 及 多 用 户 的 企业 级 平台 ， 从 而 能 够 简化 应 用 程序 的 7 


于 J2EE 只 是 一 个 标准 而 不 是 一 个 成 熟 的 产 
只 要 开发 的 应 用 程序 符合 JPEE 的 标准 ， 就 


上 。 这 种 标准 ， 使 得 开发 人 员 


所 以 ， 本 题 的 答案 为 A。 
13. 答案 : D。 


分 析 : 本 题 考察 的 是 Java 异常 处 理 知识 。 
异常 是 指 程序 运行 时 《〈 非 编译 时 ) 所 发 生 的 非 正常 情况 或 错误 ， 当 程序 违反 了 语义 规则 


时 ，JVM 就 会 将 出 现 的 错误 表示 为 一 个 异常 
获 ， 然 后 进行 处 理 。 而 异常 处 表 
Java 语言 提供 了 两 种 错误 的 处 弄 


拥有 共同 的 父 类 : Throwable。 


抛 出 。 这 个 异常 可 以 在 catch 程序 块 中 


和 发 和 部 署 。 正 是 


品 ， 因 此 ， 目 前 有 很 多 不 同类 型 的 PEE 服务 器 。 
ti 可 以 部 署 在 遵循 了 J2EE 的 开发 标准 的 PEE 服务 器 
只 需要 专注 于 各 种 应 用 系统 的 商业 罗 辑 与 架构 设计 ， 而 不 用 过 多 
地 考虑 底层 烦琐 的 程序 编写 工作 ， 系 统 的 开发 与 部 署 效率 大 幅 提 升 。 所 以 ， 选 项 A 正确 。 


的 目的 则 是 为 了 提高 程序 的 安全 性 与 健壮 性 。 


EE 类， 分 别 为 Error 〈 错 误 ) 和 Exception( 异 常 )， 


进行 捕 


且 它 们 


Error 表示 程序 在 运行 期 间 出 现 了 非常 严重 的 错误 ， 并 且 该 错误 是 不 可 恢复 的 。 由 于 这 属 
于 JVM 层次 的 严重 错误 ， 所 以 ， 这 种 错误 会 


是 否 被 处 理 ， 因 此 ， 在 程序 ! 


不 推荐 去 捕获 Error 类 型 的 异常 ， 主 要 原因 是 运行 时 异常 多 是 由 
于 逻辑 错误 导致 的 ， 属 于 应 该 解决 的 错误 ， 也 就 是 说 一 个 正确 的 程序 中 


导致 程 序 终 | 


上 执行 。 此 外 ， 编 


译 器 不 会 检查 Error 
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是 不 应 该 存在 Error 


Java 程序 员 


梧 试 笔试 真题 尼 


的 。OutOfMemoryError、ThreadDeath 等 都 属于 错误 。 当 这 些 异常 及 生 时 ，JVM 一 般 会 选择 


将 线 


程 终 止 。 


Exception 表示 可 恢复 的 异常 ， 是 编译 器 可 以 


它 包 含 两 种 


提 到 的 。 


(Runtime Exception〉 和 检查 异常 《Checked Exception)。 


段 ,Java 编 


把 对 


接 数 


1) 检查 异常 是 在 程序 中 最 经 常 碰 到 的 异常 
的 异常 都 是 检查 异常 ， 比 如 最 常见 的 IO 异常 和 SQL 异常 。 对 了 


译 器 强制 程序 去 


鲍 说 ， 
天 吊 


的 处 理 的 代码 放 到 catch 块 " 


上 获 此 类 型 的 异常 , 即 把 可 能 会 出 现 这 些 异常 
PF。 这 种 异常 一 般 在 如 下 几 种 情况 中 使 用 : 


珠 


所 有 继承 自 Exception 3 


且 不 是 运行 时 异 稼 


这 种 异常 ， 都 发 生 在 编译 阶 
的 代码 放 到 try 块 中 ， 


QD 异常 的 发 生 并 不 会 导致 程序 出 错 ， 进 行 处 理 后 可 以 继续 执行 后 续 的 操作 。 例 如 ， 当 连 


据 库 失 败 后 ， 可 以 重新 连接 后 进行 后 续 操 作 。 


@ 程序 依赖 于 不 可 靠 的 外 部 条 件 ， 


2) 对 于 运行 时 


异常 , 编译 器 没有 强 


于 


列 如 ， 系 统 IO。 
1 对 其 进行 


上 获 并 处 理 。 如 果 不 对 这 种 异常 进行 处 理 ， 


当 出 现 这 种 异常 时 ， 会 由 JVM 来 处 理 。 在 Java 语言 中 ， 最 常见 的 运行 时 异常 有 如 下 几 种 : 
NullPointerException〈 空 指针 异常 )、ArrayStoreException (数据 存储 异常 )、ClassCastException 


(类 型 转换 异常 )、 


冲 区 溢出 异常 ) 以 及 ArithmeticException (算术 异常 ) 等。 
出 现 运 行 时 异常 后 ， 系 统 会 把 异常 
处 理 块 , 则 抛 到 最 上 层 , 如 果 是 多 线程 就 由 Thread.run() 方 法 抛 出 ,， 如果 是 单线 程 ,就 被 main0) 


方法 抛 出 。 抛 出 之 后 ， 如 果 是 线程 ， 
整个 程序 也 就 退出 了 。 所 以 ， 如 果 不 对 运行 时 异常 进行 
是 线程 中 止 ， 要 么 是 主 程序 终止 
在 使 用 异 币 处 理 时 ， 还 
1) Java 异常 处 理 用 到 了 多 态 的 概念 ， 如 果 在 异 间 处 
捕获 子 类 ， 那 么 捕获 子 类 的 代码 块 将 永远 不 会 被 执行 。 
的 写法 是 ， 首先 捕获 子 类 ， 然 后 


要 么 


-全 


和 住 


F 层 抛 出 ， 直 到 遇 到 处 理 代 码 为 1 


InexOutOfBoundException 〈 数 组 越界 异常 )、BufferOverflowException 〈 绥 


上 。 如 果 没有 


以 下 几 个 问题 : 


不 需要 注意 


正确 的 写法 


捕获 基 类 的 异常 信息 。 如 下 


处理 ， 后 果 是 非常 严重 的 ， 一 旦 发 生 ， 


里 过 程 中 ， 首 先 捕 获 了 基 类 ， 


因此 ， 


在 进行 异 向 
列 所 示 : 


错误 的 写法 


和 获 的 时 候 ， 正 确 


这 个 线程 也 就 退出 了 。 如 果 是 主 程序 抛 出 的 异常 ， 那 么 


然后 再 


try 
/access db code 
人 el) 
//deal with this exception 


} 
catch(Exception e2){} 


2) 尽早 抛 出 异常 ， 同 时 对 捕获 的 异常 进行 处 至 


try 
//access db code 
catch(Exception el) 


/deal with this exception 


} 
catch(SQLException e2){} 


E， 或 者 从 错误 中 恢复 ， 或 者 让 程序 继续 执 


行 。 对 捕获 的 异常 不 进行 任何 处 理 是 一 个 非常 不 好 的 习惯 ,这 样 的 代码 将 非常 不 利于 调试 。 


当然 ， 也 不 是 抛 出 异常 越 多 越 好 ， 对 于 有 些 异 常 类 型 ， 例 如 运行 时 异常 ， 
处 理 。 


3) 可 以 


即 可 。 


4) 异常 能 处 


里 就 处 理 
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不 能 处 理 就 抛 出 。 对 于 一 般 异 常 ， 如果 不 能 进 和 


民 据 实际 的 需求 自 定义 异常 类 ， 


这 些 自 定义 的 异常 类 只 要 继承 自 Exception 


= 


实际 上 根本 不 必 


类 


本 和 傈 过 


有 效 的 处 理 


~ 


真题 详解 篇 


最 好 转换 为 运行 时 异常 抛 出 。 对 于 没有 处 理 的 异常 ， 最 终 JVM 会 进行 处 理 。 
本 题 中 ， 对 于 选项 A， 一 个 方法 声明 了 抛 出 一 个 异常 上 只 表 明 这 个 方法 有 可 能 会 抛 出 这 个 
异常 ， 而 不 是 一 定 会 抛 出 这 个 异常 。 因 此 ， 选 项 A 错误 。 
对 于 选项 B， 如 果 出 现 的 异常 被 捕获 到 ， 并 进行 相应 的 处 理 后 ， 程 序 可 以 继续 运行 ， 而 
不 会 终止 。 因 此 ， 选 项 B 错误 。 

对 于 选项 C， 异 溃 匹 配 不 是 一 种 精确 的 匹配 ， 使 用 到 了 多 态 的 概念 ， 假 如 异常 A 是 异常 
B 的 子 类 ， 如 果 有 异常 A 抛 出 ， 在 捕获 异常 的 代码 中 ， 不 仅 可 以 匹配 异常 A， 而 且 也 可 以 匹 
配 寞 常 B。 因 此 ， 选 项 C 错误 。 

对 于 选项 D， 对 于 可 能 抛 出 的 运行 时 异常 ， 编 译 器 没有 强制 对 其 进行 声明 ， 只 有 检查 异 
常 ( 例 如 IOException)， 编 译 器 才 会 强制 要 求 在 方法 中 声明 。 因 此 ， 选 项 DD 正确 。 

所 以 ， 本 题 的 答案 为 D。 

14. 答案 : A。 

分 析 : 本 题 考 察 的 是 finally 调用 时 机 的 知识 。 

本 题 中 ， 对 于 异常 处 理 而 言 ， 即 使 有 return 语句 存在 ， 也 得 保证 finally 块 中 的 语句 能 运 
行 ， 所 以 ， 语 句 System.out.printin("Finally") 最 终 会 被 执行 ， 因 此 ， 程 序 的 输出 结果 是 Finally。 
所 以 ， 选 项 A 正确 。 

所 以 ， 本 题 的 答案 为 A。 

15. 答案 : C。 

分 析 : 本题 考察 的 是 对 JSP 中 isELIgnored 的 理解 。 

isELIgnored 属性 用 来 指定 该 JSP 文件 是 否 支 持 EL (Expression Language， 表 达 式 语言 ) 
表达 式 。 如 果 值 为 tue， 那 么 对 于 类 似 于 ${..} 这 样 的 内 容 ， 直 接 会 原样 输出 ， 而 不 会 进行 EL 
表达 式 运 算 ， 如 果 值 为 false， 那 么 表示 EL 表达 式 不 会 被 忽略 ， 该 EL 表达 式 将 会 被 执行 。 其 属 
性 配置 语法 格式 如 下 : <%G@ page isELIgnored="true | false"%> 。 所 以 ， 选 项 C 正确 。 

所 以 ， 本 题 的 答案 为 C。 

16. 答案 : B。 

分 析 : 本 题 考察 的 是 Java 语言 中 引用 知识 。 

对 于 选项 A， 在 编程 语言 中 ， 指 针 指向 一 块 内 存 ， 它 的 内 容 是 所 指 内 存 的 地 址 ;而 引用 
是 某 块 内 存 的 别名 。Java 语言 中 没有 明确 的 指针 定义 ， 但 实质 上 每 一 个 new 语句 返回 的 都 是 
一 个 指针 的 引用 ， 只 不 过 在 大 多 时 候 ，Java 语言 并 不 用 关心 如 何 操作 这 个 “指针 ”。 虽 然 引用 
在 底层 是 通过 指针 实现 的 ， 但 是 引用 和 指针 不 能 等 同 ， 例 如 指针 可 以 执行 比较 运算 和 整数 加 
减 运算 ， 而 引用 却 不 行 。 所 以 ， 选 项 A 错误 。 

对 于 选项 B， 引 用 本 身 存 储 的 对 象 的 地 址 信息 《虽然 与 指针 不 是 完全 相同 )， 而 这 个 地 址 
信息 是 存储 在 栈 中 的 ,在 声明 后 就 会 立刻 在 栈 上 分 配 存储 空间 。 在 方法 调用 传递 引用 的 时 候 ， 
对 形 参 引 用 的 值 本 身 所 做 的 修改 对 实 参 不 可 见 ， 因 此 ， 从 本 质 上 来 讲 ， 引 用 也 是 原始 数据 类 
型 (Primitive)。 所 以 ， 选 项 B 正确 。 

对 于 选项 C， 一 个 对 象 可 以 被 多 个 引用 同时 指引 ， 例 如 ，String s=”abe”; String s1=s;。 所 
以 ， 选 项 C 错误 。 

对 于 选项 D， 引 用 只 是 对 象 的 一 个 别名 ， 或 理解 为 对 象 的 地 址 。 所 以 ， 选 项 D 错误 。 

所 以 ， 本 题 的 答案 为 A。 
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17. 答案 : C。 


分 析 : 本 题 考 察 的 是 Java 包 结 构 知识 。 


在 Java 语言 中 ， 包 是 一 个 比较 抽象 的 逻辑 概念 ， 它 的 宗旨 是 把 .java 文件 〈Java 源 文 


件 )、.class 文件 (编译 后 的 文件 ) 以 及 其 他 resource 文件 (例如 .xml 文件 、.avi 文件 、.mp3 


文件 和 ,txt 文件 等 ) 有 条 理 地 进行 组 织 ， 以 供 使 用 。 


它 类 似 于 Linux 系统 的 文件 系统 ， 有 一 个 


根 ， 然 后 从 根 开始 有 目录 和 文件 ， 目 录 中 藤 套 有 目录 。 
对 于 本 题 而 言 ，java.util 是 包 名 ， 实 质 上 是 一 个 目录 结构 ， 在 这 个 包 中 ，Java 语言 提供 了 


一 些 实用 的 方法 和 数据 结构 。 例 如 ， 日 期 (Data) 


类 、 日 历 (Calendar) 类 用 于 产生 和 获取 日 


期 及 时 间 , 随机 数 (Random ) 类 用 于 产生 各 种 类 型 的 随机 数 , 除 此 以 外 , 还 提供 了 堆栈 (Stack)、 
向 量 (Vector)、 位 集合 (Bitset) 以 及 哈 希 表 (HashTable〉 等 类 。 因 此 ， 选 项 C 错误 ， 因 为 


java.util 不 是 一 个 文件 ， 而 是 一 个 /javautil 目录。 
所 以 ， 本 题 的 答案 为 C。 
18. 答案 : C。 


分 析 : 本 题 考察 的 是 Swing 类 库 知 识 。 


容器 型 构件 是 指 可 以 在 这 个 构件 中 添加 其 他 的 构件 来 构件 复杂 的 界面 应 用 程序 。 
本 题 中 ， 对 于 选项 A，JButton 是 按钮 控件 ， 用 来 响应 用 户 的 单 击 事件 ， 它 不 是 容器 型 控 


件 。 因 此 ， 选 项 A 错误 。 


对 于 选项 B，Swing 库 中 没有 正 dit 控件 。 因 此 ， 选 项 B 错误 。 
对 于 选项 C，JPanel 是 一 个 容器 型 构件 ， 可 以 在 JPanel 中 添加 其 他 的 构件 。 因此， 选项 C 


正确 。 


对 于 选项 D，JTextField 是 一 个 轻 量 级 组 件 ， 它 允许 编辑 单行 文本 ， 也 不 是 一 个 容器 型 的 


构件 。 因 此 ， 选 项 D 错误 。 
所 以 ， 本 题 的 答案 为 C。 


19. 答案 : C。 


分 析 : 本 题 考 察 的 是 线程 中 sleep0 方 法 的 知识 。 
Thread.sleep(long millis) 和 Thread.sleep(long millis, int nanos) 静 态 方法 强制 当前 正在 执行 


的 线程 休眠 《〈 即 暂停 执行 )， 当 线程 睡眠 时 ， 它 有 


年 在 某 个 地 方 ， 在 苏醒 之 前 不 会 返回 到 可 运行 


状态 。 当 睡眠 时 间 到 期 ， 则 返回 到 可 运行 状态 。 所 以 ，sleep() 方 法 指定 的 时 间 为 线程 不 会 运行 
的 最 短 时 间 。 当 线程 休眠 时 间 结 束 后 ， 会 返回 到 可 运行 状态 ， 注 意 不 是 运行 状态 ， 如 果 要 到 
运行 状态 还 需要 等 待 CPU 调度 执行 。 因 此 ，sleep0 方 法 不 能 保证 该 线程 睡眠 到 期 后 就 开始 执 


行 。 所 以 ， 选 项 C 正确 。 
所 以 ， 本 题 的 答案 为 C。 
引申 :sleep 与 wait 有 什么 区 别 ? 


sleepO 是 使 线程 暂停 执行 一 段 时 间 的 方法 。wait0 也 是 一 种 使 线程 暂停 执行 的 方法 ， 例 如 ， 
当 线 程 交 互 时 ， 如 果 线 程 对 一 个 同步 对 象 x 发 出 一 个 wait0 调 用 请 求 ， 那 么 该 线程 会 暂停 执 
行 ， 被 调 对 象 进入 等 待 状态 ， 直 到 被 唤醒 或 等 待 时 间 超 时 。 


具体 而 言 ，sleep 与 wait 的 区 别 主 要 表现 在 以 下 几 个 方面 : 


1) 原理 不 同 。sleep 是 Thread 类 的 静态 方法 ， 
程 暂停 执行 指定 时 间 ， 而 把 执行 机 会 让 给 其 他 线程 
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是 线程 用 来 控制 自身 流程 的 ， 它 会 使 此 线 
， 等 到 计时 时 间 到 时 ， 此 线程 会 自动 苏醒 。 


真题 详解 篇 


例如 ， 当 线程 执行 报时 功能 时 ， 每 一 秒 钟 打印 出 一 个 时 间 ， 那 么 此 时 就 需要 在 打印 方法 前 面 
加 上 一 个 sleep 方法 ， 以 便 让 自己 每 隔 一 秒 执行 一 次 ， 该 过 程 如 同 闹钟 一 样 。 而 wait 是 Object 
类 的 方法 ， 用 于 线程 间 的 通信 ， 这 个 方法 会 使 当前 拥有 该 对 象 锁 的 进程 等 待 ， 直 到 其 他 线程 
调用 notify 方法 (或 notifyAll 方法 ) 时 才 醒 来 ， 不 过 开发 人 员 也 可 以 给 它 指 定 一 个 时 间 ， 自 
动 醒 来 。 与 wait 配套 的 方法 有 notify 和 notifyAll。 

2) 对 锁 的 处 理 机 制 不 同 。 由 于 sleep 方法 的 主要 作用 是 让 线程 休眠 指定 的 一 段 时 间 ， 
在 时 间 到 时 自动 恢复 ， 不 涉及 线程 间 的 通信 ， 因 此 ， 调 用 sleep 方法 并 不 会 释放 锁 。 而 
wait 方法 则 不 同 ， 当 调用 wait 方法 后 ， 线 程 会 释放 掉 它 所 占用 的 锁 ， 从 而 使 线程 所 在 对 
象 中 的 其 他 synchronized 数据 可 被 其 他 线程 使 用 。 举 个 简单 例子 ， 在 小 明 拿 遥 控 器 期 间 ， 
他 可 以 用 自己 的 sleep 方法 每 隔 十 分 钟 调 一 次 电视 台 ， 而 在 他 调 台 休息 的 十 分 钟 期 间 ， 朋 
控 器 还 在 他 的 手 上 。 

3) 使 用 区 域 不 同 。 由 于 wait 方法 的 特殊 意义 ， 所 以 ， 它 必须 放 在 同步 控制 方法 或 者 同 
步 语句 块 中 使 用 ， 而 sleep 方法 则 可 以 放 在 任何 地 方 使 用 。 

4) sleep 方法 必须 捕获 异常 ， 而 Wait、notify 以 及 notifyall 不 需要 捕获 异常 。 在 sleep 的 
过 程 中 ， 有 可 能 被 其 他 对 和 象 调 用 它 的 interrupt0， 产 生 InterruptedException 异常 。 
1 于 sleep 不 会 释放 “ 锁 标 志 ” 容易 导致 死 锁 问 题 的 发 生 ， 所 以 ， 一 般 情 况 下 ， 不 推荐 
使 用 sleep 方法 ， 而 推荐 使 用 wait 方法 。 

20. 答案 : A。 

分 析 : 本 题 考 察 的 是 Java 关键 字 的 知识 。 

关键 字 是 计算 机 语言 里 事先 定义 的 、 有 特别 意义 的 标识 符 , Java 语言 有 51 个 保留 关键 字 : 
数据 类 型 字 boolean、int、long、short、byte、float、double、char、class、interface， 流 程控 制 
字 if、 else、 do、while、 for、 switch、 case、 default、 break、continue、 return、 try、 catch、 finally, 


| 


由 


Ar 人 


修饰 符 字 public、 protected、 private、 final、 void、 static、 strictfp、 abstract、 transient、 synchronized、 
volatile、native， 动 作 字 package、import、throw、throws、extends、implements、this、super、 
instanceof、new， 保 留 字 true、false、null、goto、const。 其 中 ，const 和 goto 虽然 被 保留 但 未 
被 使 用 ， 不 能 使 用 保留 关键 字 来 命名 类 、 方 法 或 变量 。 

本 题 中 ， 对 于 选项 A，integer 不 是 Java 语言 的 关键 字 ， 而 Integer 却 是 Java 语言 的 关键 
字 。 所 以 ， 选 项 A 不 正确 。 

对 于 选项 B 与 选项 C，float 和 double 是 Java 语言 的 两 个 基本 数据 类 型 ， 因 此 ， 它 们 都 是 
Java 的 关键 字 。 所 以 ， 选 项 B 与 选项 C 正确 。 

对 于 选项 D， 在 switch 语句 中 ，default 分 支 是 一 个 用 来 匹配 当 不 满足 前 面 所 有 分 支 的 条 
件 时 的 特殊 的 分 支 ， 因 此 ， 它 也 是 Java 语言 的 关键 字 。 所 以 ， 选 项 D 正确 。 

所 以 ， 本 题 的 答案 为 A。 

21. 答案 : B。 

分 析 : 本 题 考察 的 是 WEB_INF 目录 结构 知识 。 

WEB-INF 是 Web 应 用 的 安全 目录 。 所 谓 安全 目录 就 是 客户 端 无 法 访问 ， 只 有 服务 端 可 
以 访问 的 目录 。 如 果 想 在 页 面 中 直接 访问 其 中 的 文件 ， 必 须 通 过 web.xml 文件 对 要 访问 的 文 
件 进行 相应 的 映射 才 行 。WEB-INF 文件 夹 下 除了 web.xml 外 ， 还 存在 一 个 classes 文件 夹 ， 用 
以 放置 *.class 文件 ， 这 些 *.class 文件 是 设计 人 员 编 写 的 类 库 ， 实 现 了 JSP 页 面前 台 与 后 台 
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服务 的 分 离 ， 使 得 网 站 的 维护 非常 方便 。web.xml 文件 为 网 站 部 署 描述 XML 文件 ， 它 对 网 站 


的 部 署 非常 重要 。 


因此 ，web.xml 是 必 不 可 少 的 文件 。 所 以 ， 选 项 B 正确 。 


所 以 ， 本 题 的 答案 为 B。 


22. 答案 : A 


o 


分 析 : 本 题 考察 的 是 位 运算 符 知 识 。 
在 Java 语言 中 ， 久 《与 ) 是 二 进 制 与 操作 运算 符 ， 其 功能 是 参与 运算 的 两 数 对 应 的 二 进 


位 进行 与 操作 。 只 


本 题 中 , 十 进 


这 两 个 制 数 相 与 的 结果 为 0100， 对 应 的 十 进 制 数 为 4。 所 以 ， 选 项 A 正确 。 


有 对 应 的 两 个 二 进位 均 为 1 时 ， 结 果 位 才 为 1， 否则 为 0。 
制 数字 7 的 二 进 制 表 示 为 0111, 十 进 制 数字 4 的 二 进 制 表示 为 0100, 因此 ， 


一 辐 


所 以 ， 本 题 的 答案 为 A。 


23. 答案 : B 


o 


分 析 : 本 题 考察 的 是 类 型 转换 知识 。 


在 Java 语言 


Ph， 当 参与 运算 的 两 个 变量 的 数据 类 型 不 同时 ， 就 需要 进行 隐 式 的 数据 类 型 


转换 ， 转 换 的 原则 为 : 从 低 精 度 向 高 精度 转换 ， 即 优先 级 满足 byte<short<char<int<long<float 
<double。 例 如 ， 不 同 数据 类 型 的 值 在 进行 运算 时 ，short 类 型 数据 能 够 自动 转 为 int 型 ，int 类 


型 数据 能 够 自动 转换 为 float 型 等 。 反 之 ， 则 需要 通过 强制 类 型 转换 来 实现 。 在 Java 语言 中 ， 


类 型 转换 可 以 分 为 以 下 几 种 类 型 : 
(1) 类 型 自动 转换 
低级 数据 类 型 可 以 自动 转换 为 高 级 数据 类 型 ， 表 8 给 出 了 常见 的 自动 转换 条 件 。 


表 8 常见 的 自动 转换 条 件 


操作 数 1 类 型 操作 数 2 类 型 转换 后 的 类 型 
long byte short char int long 
int byte short char int 
float byte short int char long float 
double byte short int long char float double 
NS 二 汪汪 站 | -下 
当 类 型 自动 转换 时 ， 需 要 注意 以 下 几 点 : 


1) char 类 型 的 数据 转换 为 高 级 类 型 (例如 int、long 等 )， 会 转换 为 对 应 的 ASCII 码 。 
2) byte、char 和 short 类 型 的 数据 在 参与 运算 的 时 候 ， 会 自动 转换 为 int 型 。 但 当 使 用 += 
运算 的 时 候 ， 就 不 会 产生 类 型 的 转换 。 


3) 在 Java 语 


言 中 ， 另 外 一 个 与 C/C++ 语言 不 同 的 地 方 是 ， 基 本 数据 类 型 与 boolean 类 型 


是 不 能 相互 转换 的 。 


总 之 ， 当 有 多 种 类 型 的 数据 混合 运算 时 ， 系 统 首先 自动 将 所 有 数据 转换 成 容量 最 大 的 那 
一 种 数据 类 型 ， 然 后 再 进行 计算 。 

(2) 强制 类 型 转换 

当 需 要 从 高 级 类 型 转换 为 低级 数据 类 型 的 时 候 ， 就 需要 进行 强制 类 型 转换 ， 表 9 给 出 了 
可 以 进行 强制 类 型 转换 的 条 件 。 
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表 9 强制 类 型 转换 的 条 件 


原 操作 数 类 型 转换 后 操作 数 类 型 
byte char 
char byte 
short byte char 
int byte short char 

long byte short char 
float byte short char int long 

double byte short char int long 


需要 注意 的 是 ， 在 进行 强制 类 型 转换 的 时 候 可 能 会 丢失 精度 。 

对 于 本 题 而 言 ， 赋值 语 句 long temp=(int)3.9 的 过 程 如 下 : 首先 ， 把 浮 点 数 3.9 强制 转 
化 为 int 类 型 ， 在 转换 的 过 程 中 会 直接 丢掉 小 数 部 分 ， 转 换 结果 为 3， 接 着 在 赋值 给 long 
型 变量 temp 的 时 候 ， 会 隐 式 地 将 该 值 转换 为 long 类 型 ， 由 于 是 从 低 精 度 向 高 精度 转换 ， 
所 以 , 在 转换 过 程 中 不 会 有 精度 丢失 ,转换 结果 仍然 为 3; 接着 执行 语句 ttmp%=2， 该 语 
句 等 价 于 temp=temp%2， 用 来 求 temp 除 以 2 的 余数 ，3%2， 显 然 ， 结 果 为 1。 所 以 ， 选 
项 B 正确 。 
所 以 ， 本 题 的 答案 为 B。 

24. 答案 : B。 

分 析 : 本 题 考 察 的 是 对 Servlet 中 常用 方法 的 理解 。 

HttpServletResponse 对 象 代 表 服 务 器 的 响应 ， 该 对 象 封 装 了 向 客户 端 发 送 数据 、 发 送 响应 
头 及 发 送 响应 状态 但 的 方法 。HttpServletResponse 接口 提供 了 重 写 URL 的 方法 : 

public java.lang.String encodeURL(java.lang.String url) 

该 方法 的 实现 机 制 如 下 : 首先 判断 当前 的 Web 组 件 是 否 启用 了 Session， 如 果 没 有 启用 
Session， 直 接 返 回 参 数 url。 再 判断 客户 端 浏览 器 是 否 支 持 Cookie， 如 果 支 持 Cookie， 则 直接 
返回 参数 url， 如果 不 支持 Cookie， 就 在 参数 url 中 加 入 Session ID 信息 ， 然 后 返回 修改 后 的 
url。 因此 ， 这 个 方法 可 以 用 来 把 session ID 加 入 到 URL 中 。 上 所以， 选项 B 正确 。 

所 以 ， 本 题 的 答案 为 B。 

25. 答案 : D。 

分 析 : 本 题 考察 的 是 Swing 知识 。 

Swing 是 一 个 用 于 开发 Java 应 用 程序 用 户 界面 的 开发 工具 包 ， 它 提供 了 大 量 模块 化 组 件 
来 方便 开发 人 员 构建 用 户 界 面 。 在 使 用 Swing 开发 界面 应 用 程序 的 时 候 ， 图 形 界面 至 少 要 有 
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一 个 顶级 Swing 容器 ， 这 个 顶级 Swing 容器 主要 用 来 为 其 他 Swing 组 件 在 屏幕 上 的 绘制 和 处 
理事 件 提供 支持 ， 常 见 的 顶级 容器 为 JErame、JDialog 和 JApplet。 至 于 其 他 的 控件 ， 可 以 根 
据 实际 的 需求 而 定 ， 可 以 使 用 ， 也 可 以 不 用 。 所 以 ， 选 项 D 正确 。 

所 以 ， 本 题 的 答案 为 D。 

26. 答案 : D。 

分 析 : 本 题 考察 的 是 Java 命名 知识 。 
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Java 标识 符 可 以 是 字母 、 数 字 、$、_( 下 划 线 )， 但 不 可 用 数字 开头 ， 且 不 可 以 是 Java 的 


关键 字 ， 


标识 符 在 语法 层面 给 出 了 如 何 定义 一 个 合法 的 标识 符 。 在 实际 使 用 的 时 候 为 了 增加 


程序 的 可 读 性 ，Java 还 根据 不 同 的 类 型 提供 了 几 个 命名 的 原则 〈 不 是 强制 的 ， 只 是 为 了 增强 
程序 的 可 读 性 ， 降 低 程序 的 维护 成 本 ): 


包 名 : 全 部 小 写 ( 例 如 mypacket)。 

类 名 : 每 个 单词 的 首 字母 大 写 〈 例 如 MyClass )。 

变量 名 : 第 一 个 字母 小 写 ， 以 后 每 个 单词 的 首 字 母 大 写 〈 例 如 firstName )。 

常量 : 全 部 使 用 大 写字 母 ， 单 词 间 用 下 划 线 隔 开 〈 例 如 MAX _ LEN )。 

从 上 面 分 析 可 知 ， 选 项 D 正确 ， 选 项 A 和 选项 B 错误 。 接 口 也 可 以 看 作 一 种 特殊 的 类 ， 
所 以 ， 接 口 名 的 首 字 母 也 大 写 ， 因 此 ， 选 项 C 错误 。 

所 以 ， 本 题 的 答案 为 D。 


2 


答案 : B。 


分 析 : 本 题 考察 的 是 重 载 知识 。 


1) 


重 载 是 在 一 个 类 中 多 态 性 的 一 种 表现 ， 是 指 在 一 个 类 中 定义 了 多 个 同名 的 方法 ， 它 们 或 
有 不 同 的 参数 个 数 或 有 不 同 的 参数 类 型 。 在 使 用 重 载 时 ， 需 要 注意 以 下 几 点 : 


重 载 是 通过 不 同 的 方法 参数 来 区 分 的 ， 例 如 不 同 的 参数 个 数 、 不 同 的 参数 类 型 或 不 同 


的 参数 顺序 。 


2) 


不 能 通过 方法 的 访问 权限 、 返 回 值 类 型 和 抛 出 的 异常 类 型 来 进行 重 载 。 


对 于 选项 A， 这 个 方法 有 三 个 参数 ， 而 题目 中 给 出 的 方法 只 有 两 个 参数 。 因 此 ， 选 项 A 


是 合法 的 。 


对 于 选项 B， 这 个 方法 与 题目 中 给 出 的 方法 同名 而 且 有 相同 的 参数 类 表 ， 因 此 ， 
两 者 是 相同 的 方法 ， 所 以 ， 这 个 方法 被 加 入 Test 中 是 不 合法 的 。 因此， 选项 B 是 不 合 


法 的 。 


对 于 选项 C， 这 个 方法 的 参数 类 型 为 nt， 而 题目 中 的 参数 类 型 为 oat。 因 此 ， 选 项 C 是 


合法 的 。 


对 于 选项 D， 这 个 方法 参数 的 个 数 与 类 型 与 题目 中 的 方法 都 不 同 。 因 此 ， 选 项 D 是 合法 的 。 
所 以 ， 本 题 的 答案 为 B。 


28 . 


答案 : A。 


分 析 : 本 题 考察 的 是 数组 知识 。 
数组 可 以 看 成 是 多 个 相同 数据 类 型 数据 的 组 合 。 在 Java 语言 中 , 使 用 关键 字 new 创建 数 


组 对 象 ， 


格式 为 : 数组 名 =new 数组 元 素 类 型 [数组 元 素 个 数 ];， 例 如 ，int[] arr = new int[5];。 


二 维 数组 可 以 看 成 是 以 数组 为 元 素 的 数组 。 例 如 ，int a[][] = {{1,2}, {3,4,5,6},{7,8,9}};。 
本 题 中 ， 对 于 选项 A， 定 义 了 一 个 数组 实例 arr， 并 给 其 分 配 了 可 以 存放 10 个 int 变量 大 


小 的 存储 空间 。 因 此 ， 选 项 A 正确 。 


对 于 选项 B， 声 明了 一 个 float 类 型 的 变量 ， 但 却 把 一 个 float 数组 类 型 的 实例 赋值 给 它 
因此 ， 选 项 B 错误 。 

对 于 选项 C, 声明 了 一 个 char 数组 类 型 的 变量 , 但 却 把 一 个 字符 串 类 型 的 变量 赋值 给 它 
因此 ， 选 项 C 错误 。 


168 


真题 详解 篇 


对 于 选项 D， 正 确 的 写法 应 为 ntia[]D] = {{4, 5, 6} ,{1, 2, 3}};。 因 此 ， 选 项 DD 错误 。 

所 以 ， 本 题 的 答案 为 A。 

29. 答案 : A。 

分 析 : 本 题 考 察 的 是 作用 域 修饰 符 的 知识 。 

对 于 选项 A 与 选项 C， 被 public 修饰 的 类 的 作用 域 最 大 ， 可 以 被 程序 中 任意 的 类 使 用 。 
因此 ， 选 项 A 正确 ， 选 项 C 错误 。 

对 于 选项 B， 只 有 当 一 个 类 被 final 修饰 时 ， 才 不 能 被 其 他 类 继承 。 因 此 ， 选 项 B 错误 。 

对 于 选项 D， 当 作用 域 为 default 时 (不 被 public 修饰 )， 仅 能 被 本 程序 包 中 的 类 使 用 。 
因此 ， 选 项 D 错误 。 

所 以 ， 本 题 的 答案 为 A。 

30. 答案 : B。 

分 析 : 本 题 考察 的 是 JDK 知识 。 

对 于 选项 A，JDK 中 的 编译 器 为 javac.exe， 可 以 用 来 把 Java 代码 编译 为 中 间 代 码 .class 
文件 。 所 以 ， 选 项 A 错误 。 

对 于 选项 B，java.exe 是 Java 解释 器 ， 用 来 解释 执行 通过 javac 编译 生成 的 .class 文件 。 
所 以 ， 选 项 B 正确 。 

对 于 选项 C，JDK 文档 生成 所 使 用 的 命令 为 javadoc.exe， 而 不 是 java.exe。 所 以 ， 选 项 C 
着 误 。 

对 于 选项 D, JDK 也 提供 了 很 多 类 分 析 工 具 , 例如 ,jstack 用 来 查看 线程 情况 (观察 JVM 
中 当前 所 有 线程 的 运行 情况 和 线程 当前 状态 ， 可 以 查看 堆栈 信息 、 查 看 运行 的 线程 的 方法 调 
用 关系 )，jmap 用 来 查看 内 存 堆 情 况 。 所 以 ， 选 项 DD 错误 。 

所 以 ， 本 题 的 答案 为 B。 

31. 答案 : C。 

分 析 : 本 题 考察 的 是 构造 方法 知识 。 

构造 方法 是 一 种 特殊 的 方法 ， 用 来 在 对 象 实例 化 时 初始 化 对 象 的 成 员 变 量 。 在 Java 语言 
中 ， 构 造 方法 具有 以 下 特点 : 

1) 构造 方法 必须 与 类 的 名 字 相 同 ， 并 且 不 能 有 返回 值 〈 返 回 值 也 不 能 为 void )。 

2) 每 个 类 可 以 有 多 个 构造 方法 。 当 开发 人 员 没 有 提供 构造 方法 时 ， 编 译 器 在 把 源 
代码 编译 成 字 节 码 的 过 程 中 会 提供 一 个 没有 参数 默认 的 构造 方法 ， 但 该 构造 方法 不 会 
执行 任何 代码 。 如 果 开 发 人 员 提 供 了 构造 方法 ， 那 么 编译 器 就 不 会 再 创建 默认 的 构造 
方法 。 

3) 构造 方法 可 以 有 0 个、1 个 或 1 个 以 上 的 参数 。 

4) 构造 方法 总 是 伴随 着 new 操作 一 起 调用 , 不 能 由 程序 的 编写 者 直接 调用 ， 必 须要 由 系 
统 调 用 。 构 造 方法 在 对 象 实例 化 的 时 候 会 被 自动 调用 ， 且 只 运行 一 次 ， 而 普通 的 方法 是 在 程 
序 执行 到 它 的 时 候 被 调用 的 ， 可 以 被 该 对 象 调用 多 次 。 

5) 构造 方法 的 主要 作用 是 完成 对 象 的 初始 化 工作 。 

6) 构造 方法 不 能 被 继承 ， 因 此 ， 它 不 能 被 覆盖 ， 但 是 构造 方法 能 够 被 重 载 ， 可 以 使 用 不 
同 的 参数 个 数 或 参数 类 型 来 定义 多 个 构造 方法 。 


>- 
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7) 子 类 可 以 通过 关键 字 super 来 显 式 地 调用 父 类 的 构造 方法 ， 当 父 类 没有 提供 无 参数 的 
构造 方法 时 ， 子 类 的 构造 方法 中 必须 显 式 地 调用 父 类 的 构造 方法 ， 如 果 父 类 中 提供 了 无 参数 
的 构造 方法 ， 此 时 子 类 的 构造 方法 就 可 以 不 显 式 地 调用 父 类 的 构造 方法 ， 在 这 种 情况 下 编译 
器 会 默认 调用 父 类 的 无 参数 的 构造 方法 。 当 有 父 类 时 ， 在 实例 化 对 象 时 ， 会 首先 执行 父 类 的 
构造 方法 ， 然 后 才 执 行 子 类 的 构造 方法 。 

8) 当 父 类 和 子 类 都 没有 定义 构造 方法 时 ， 编 译 器 会 为 父 类 生成 一 个 默认 的 无 参数 
的 构造 方法 ， 给 子 类 也 生成 一 个 默认 的 无 参数 的 构造 方法 。 此 外 ， 默 认 构 造 器 的 修饰 
符 只 与 当前 类 的 修饰 符 有 关 ( 例 如 ， 如 果 一 个 类 被 定义 为 public， 那 么 它 的 构造 方法 也 
是 public)。 

从 以 上 分 析 可 知 ， 选 项 A 和 选项 B 正确 ， 选 项 C 错误 。 

对 于 选项 D， 在 Java 语言 中 ， 当 类 在 实例 化 时 ， 会 自动 调用 构造 方法 ， 而 不 能 显 式 地 调 
用 构造 方法 。 因 此 ， 选 项 D 正确 。 

所 以 ， 本 题 的 答案 为 C。 

32. 答案 : B。 

分 析 : 本 题 考 察 的 是 构造 方法 知识 。 

对 于 选项 A， 类 在 定义 时 只 是 定义 了 一 个 引用 类 型 ， 并 不 会 调用 构造 方法 。 因 此 ， 选 项 
A 错误 。 

对 于 选项 B， 一 般 情况 下 构造 方法 只 在 对 象 被 创建 时 被 调用 ， 例 如 通过 new 创建 一 个 新 
秆 象 时 会 调用 构造 方法 。 因 此 ， 选 项 B 正确 。 
对 于 选项 C， 在 使 用 对 象 变量 时 对 象 已 经 存在 ， 因 此 ， 也 不 会 调用 构造 方法 来 创建 新 的 
。 因 此 ， 选 项 C 错误 。 
对 于 选项 D， 调 用 对 象 方法 的 前 提 是 这 个 对 象 已 经 存在 ， 因 此 ， 调 用 对 象 方法 时 不 会 调 
用 构造 方法 。 因 此 ， 选 项 D 错误 。 

所 以 ， 本 题 的 答案 为 B。 

33. 答案 : C。 
分 析 : 本 题 考察 的 是 break 知识 。 
关键 字 break 的 作用 直接 强行 跳出 当前 循环 ,不 再 执行 剩余 部 分 代码 。 当 循环 中 遇 到 break 
语句 时 ， 和 忽略 循 环 体 中 任何 其 他 语句 和 循环 条 件 测试 ， 程 序 控制 在 循环 后 面 语句 重新 开始 。 
所 以 ， 当 多 层 循 环 嵌 套 ， 并 且 break 语句 出 现在 杉 套 循环 中 的 内 层 循环 时 ， 它 将 仅仅 只 是 终止 
了 内 层 循环 的 执行 ， 而 不 影响 外 层 循环 的 执行 。 
于 break 只 能 跳出 当前 的 循环 ,那么 如 何 才 能 实现 跳出 多 重 循环 呢 ? 可 以 在 多 重 循环 的 
外 面 定 义 一 个 标识 ， 然 后 在 循环 体 里 使 用 带 有 标识 的 break 语句 即 可 跳出 多 重 循环 。 
程序 示例 如 下 : 


> 


对 象 


public class Test 


1 
public static void main(String[] args) 
{ 
out: 
for(int 1=0;1<5;i++) 
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{ 
for(int j=0;j<5;j++) 
{ 
if0>=2) 
break out; 
System.out.printing); 
} 
} 
System.out.println("break"); 
} 
} 
程序 的 运行 结果 为 
0 
1 
break 


上 作 
语句 。 

从 以 上 分 析 可 以 看 出 ，break 可 以 借助 标记 跳出 多 重 循环 ， 选 项 C 正确 。 

所 以 ， 本 题 的 答案 为 C。 

34. 答案 : B。 

分 析 : 本 题 考察 的 是 对 Java 变量 名 定义 规则 的 理解 。 

对 于 选项 A， 这 个 名 称 是 以 数字 开头 的 ， 因 此 ， 它 不 符合 定义 规划。 所 以 ， 选 项 A 
错误 。 

对 于 选项 B， 符 合 定义 规则 。 所 以 ， 选 项 B 正确 。 

对 于 选项 C 和 选项 DD, 它们 是 Java 中 的 关键 字 ,extends 是 类 继承 的 关键 字 , implements 
是 实现 接口 的 关键 字 ， 它 们 不 能 用 来 作为 变量 名 称 。 所 以 ， 选 项 C 和 选项 DD 错误 。 

所 以 ， 本 题 的 答案 为 了 B。 

35. 答案 : D。 

分 析 : 本 题 考 察 的 是 对 JavaScript 的 理解 。 

对 于 选项 A，JavaScript 是 弱 类 型 语言 《也 称 为 弱 类 型 定义 语言 ， 与 强 类 型 定义 相反 。 弱 
类 型 语言 允许 将 一 块 内 存 看 作 多 种 类 型 ， 比 如 直接 将 整 型 变量 与 字符 变量 相 加 。C/C++ 是 静态 
语言 ， 是 强 类 型 语言 ，Perl 与 PHP 是 动态 语言 ， 但 也 是 弱 类 型 语言 )， 只 有 一 种 类 型 var。 所 
以 ， 选 项 A 错误 。 

对 于 选项 B，Integer.parseInt(value) 是 Java 语言 中 的 方法 ， 而 不 是 JavaScript 的 方法 。 所 
以 ， 选 项 B 错误 。 

对 于 选项 C，JavaScript 中 验证 一 个 数据 是 否 是 数字 是 存在 方法 的 ， 可 以 人 
数 判 断 ， 也 可 以 使 用 正则 表达 式 判 断 。 所 以 ， 选 项 C 错误 。 

对 于 选项 D，JavaScript 提供 了 一 个 isNaNO 函 数 用 于 检查 其 
选项 DD 正确 。 

所 以 ， 本 题 的 答案 为 D。 


i 


中 , 当 内 部 循环 执行 到 j 等 于 2 时, 程序 跳出 双重 循环 ,执行 System.outprintin ("break") 


] isNaNO 函 


上 


| 


Sh 


数 是 否 是 非 数字 值 。 所 以 ， 
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36. 答案 : D。 


分 析 : 本 题 考察 的 是 Web 服务 器 知识 。 


Web 服务 器 指 的 是 提供 Web 功能 的 服务 器 ， 主 要 就 是 HTTP 服务器， 包括 图 片 的 下 载 等 


一 系列 和 文本 相关 的 资源 。Web 服务 器 支持 以 HTTP 协议 的 方式 来 访问 ， 当 Web 服务 器 接收 
到 一 个 HTTP 请 求 时 ， 它 同样 会 以 HTTP 协议 格式 返回 
的 HTML 页 面 ， 也 可 以 是 结果 处 理 的 一 个 动态 的 页 面 ， 还 可 以 是 音频 、 视 频 等 信息 。 为 了 处 
理 一 个 请 求 ，Web 服务 器 可 以 做 出 一 个 响应 ， 并 进行 页 面 跳 转 ， 或 者 把 动态 响应 的 产生 委托 
给 一 些 其 他 的 程序 ， 例 如 CGI 脚本 、JSP、Servlet 或 者 一 些 其 他 的 服务 器 端 程序 。Web 服务 


器 一 般 都 使 用 了 一 些 特有 的 机 制 ( 例 如 容错 机 


一 个 响应 ， 这 个 响应 可 以 是 一 个 静态 


断 的 提供 服务 。 常 见 的 Web 服务 器 有 IIS 和 Apache。 
应 用 服务 器 提供 访问 业务 逻辑 的 途径 以 供 客 户 端 应 用 程序 使 用 .具体 而 言 , 它 通过 HTTP、 
TCP/IP、IIOP (Internet Inter-ORB Protocol， 互 联网 内 部 对 象 请 求 代 理 协议 ) 或 JRMP (Java 


Remote Method Protocol，Java 远程 方法 协议 ) 等 来 提 任 


站) 来 保证 Web 服务 器 有 较 好 的 扩展 性 和 不 间 


性 ， 同 样 使 用 了 一 些 可 扩展 性 和 容错 机 制 。 除 此 之 外 ， 


业务 逻辑 接口 。 为 了 提高 系统 的 可 靠 


它 还 为 应 用 的 开发 提供 了 许多 服务 ， 


川 


例如 事务 管理 、 安 全 管理 及 对 象 生命 周期 管理 等 。 常见 的 应 用 服务 器 有 BEA WebLogic Server、 
IBM WebSphere Application Server、IPlanet Application Server、Oracle9i Application Server、JBoss 


和 Tomcat 等 。 


Web 服务 器 


般 是 通用 的 ， 而 应 用 服务 器 一 般 是 专 月 
程序 而 不 能 处 理 ASPX 或 PHP。 需 要 注意 的 是 ，Web 服务 器 与 应 用 服务 器 是 并 列 关 系 ， 两 者 


日 的 ， 例 如 Tomcat 只 处 理 Java 应 用 


不 存在 相互 包容 关系 。 在 使 用 的 时 候 , 如 果 访 问 的 页 面 只 有 HTML, 用 Web 服务 器 就 足够 了 ， 
但 是 如 果 是 JSP， 此 时 就 需要 应 用 服务 器 ， 因 为 只 有 应 用 服务 器 才能 解析 JSP 里 的 Java 代码， 


玫 将 解析 结果 以 HTML 的 格式 返回 给 用 户 。 
从 上 面 的 分 析 可 以 看 


Hh ， 选 项 A、 选 项 B 和 选项 C 都 可 以 作为 JSP 的 服务 器 。 


对 于 选项 DD，PWS (Personal Web Server, 个 人 Web 服务 器 ) 是 微软 开发 的 个 人 网 站 服务 


器 ， 主 要 应 用 于 解决 个 人 信息 共享 和 Web 开发 。 它 是 
以 自动 创建 个 性 化 了 


Web 站 点 设置 。 


个 桌面 形 的 Web 服务 器 ， 使 用 它 可 
FE 页 ， 以 拖 放 的 方式 发 布 文档 ， 在 它 的 帮助 下 ， 用 户 可 以 快速 简便 地 进行 


于 它 只 是 一 个 Web 服务 器 ， 因 此 ， 它 无 法 作为 JSP 的 服务 器 。 所 以 ， 选 项 


D 正和 有 


Jsp:include: 


所 以 ， 本 题 的 答案 为 D。 
37. 答案 : D。 
分 析 : 本 题 考察 的 是 对 JSP 操作 指令 的 理解 。 
JSP 总 共有 6 个 操作 指 今 : 

jsp:forward 与 jsp:plugin。 以 下 将 分 别 对 这 儿 种 指令 进行 介绍 。 


] 来 在 页 面 被 请 求 的 时 候 引 入 一 个 文 伯 


Jsp:include 、jsp:useBean、jsp:setProperty、jsp:getProperty、 


DH 


使 用 示例 如 下 所 示 : 


< jsp:include page="test.jsp " flush="true"> 
< jsp:param name="name" value="value"/> 


</ jsp:include> 


以 上 代码 表示 在 当前 文件 中 可 以 引入 testjsp 文件 。 
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jsp:useBean: 用 来 寻找 或 者 实例 化 一 个 JavaBean。 它 使 得 开发 人 员 既 可 以 发 挥 Java 组 件 
重用 的 优势 ， 同 时 也 避免 了 损失 JSP 区 别 于 Servlet 的 方便 性 。 使 用 示例 如 下 所 示 ; 


<jsp:useBean id="car" scope="session" class="com.Car" > 


以 上 代码 表示 实例 化 了 一 个 com.Car 类 的 实例 。 
jsp:setProperty: 用 来 设置 已 经 实例 化 的 Bean 对 象 的 属性 。 使 用 示例 如 下 所 示 : 


< jsp:setProperty name=" car " property="colour" value="red" /> 


以 上 代码 用 来 设置 名 字 为 car 的 实例 的 colour 属性 为 red。 
jsp:getProperty: 用 来 获取 某 个 JavaBean 的 属性 。 使 用 示例 如 下 所 示 : 


Colour= < jsp:getProperty name="car" property="colour"></ jsp:getProperty> 


以 上 代码 用 来 获取 名 字 为 car 的 实例 的 colour 属 
jsp:foward: 用 来 把 请 求 转 到 一 个 新 页 面 。 使 用 示例 如 下 所 示 : 


全 到 


ha 


<jsp:forward page="/Servlet/login" /> 
以 上 代码 把 当前 页 面 重 定向 到 /Servlet/login 来 处 理 。 
jsp:plugin: 用 于 在 浏览 器 中 播放 或 显示 一 个 对 象 。 使 用 这 个 动作 能 插入 所 需 的 特定 的 浏 
览 器 的 OBJECT 或 EMBED 元 素来 指定 浏览 器 运行 一 个 JAVA Applet 所 需 的 插件 。 使 用 示例 
如 下 所 示 : 


< jsp:plugin type="applet" codebase="/ch5" code="Hello.class" height="40" width="320"> 


以 上 代码 用 来 在 浏览 器 中 运行 一 个 applet 插件 。 
此 可 见 ， 选 项 DD 中 的 import 不 是 JSP 的 操作 指令 。 所 以 ， 选 项 DD 正确 。 
所 以 ， 本 题 的 答案 为 D。 
38. 答案 : C。 
分 析 : 本 题 考察 的 是 对 Java 访问 控制 关键 字 的 理解 。 
在 Java 语言 中 ， 类 的 访问 控制 关键 字 有 public、protected 和 private。 而 关键 字 this 用 来 
指向 当前 实例 对 象 , 它 的 一 个 非常 重要 的 作用 就 是 用 来 区 分 对 象 的 成 员 变 量 与 方法 的 形 参 ( 当 
一 个 方法 的 形 参与 成 员 变 量 有 着 相同 名 字 的 时 候 , 就 会 履 放 成 员 变 量 )。 为 了 能 够 对 关键 字 this 
有 一 个 更 好 的 认识 ， 首 先 创 建 一 个 类 People， 示 例如 下 ; 


class People 


{ 


String name; 

// 正 确 的 写法 
public People(String name) 
{ 


this.name=name; 
} 
// 错 误 的 写法 
public People(String name) 
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} 


{ 


name~name; 


} 


上 例 中 ， 第 一 个 构造 方法 使 有 
法 的 形式 参数 。 对 了 
因此 ， 对 于 语句 name=name， 等 号 左边 和 右边 的 两 个 name 都 代表 的 是 形式 参数 。 在 这 种 情 
况 下 ， 只 有 通过 this 才能 访问 到 成 员 变量 。 


所 以 ， 本 题 的 答案 为 C。 


39. 答案 


: 了 B。 


山 | 


分 析 : 本 题 考察 的 是 了 对 Swing 布局 的 理解 。 


Swing 是 一 个 用 于 开发 Java 应 用 程序 用 户 界 面 的 开发 工具 包 。 利 


功能 和 模块 化 组 件 ， 开 发 人 员 可 以 只 用 很 少 的 代码 来 创建 优雅 的 用 户 


日 this.name 来 表示 左边 的 值 为 成 员 变 量 ， 而 不 是 这 个 构造 方 
第 二 个 构造 方法 ， 由 于 在 这 个 方法 中 形 参与 成 员 变量 有 着 相同 的 名 字 ， 


用 Swing 丰富 、 灵 活 的 
界面 。 


I 果 在 一 行 无 法 放下 ， 就 


具体 而 言 ，Swing 中 主要 有 如 下 几 种 布局 容器 : 

1) FlowLayout: 把 控件 按照 顺序 由 左 问 右 水 平 放 置 在 容器 中 ， 妇 
放 到 下 一 行 。 

2) BorderLayout: 将 整个 容器 划分 成 东南 西北 中 五 个 方位 来 放置 控件 ， 放 置 控件 时 需要 
指定 控件 放置 的 方位 。 


3)BoxLayout: 可 以 指定 在 容器 中 


要 更 为 灵活 的 


个 布局 容器 。 


P 是 否 对 控件 进行 水 平 或 者 垂直 放置 , 它 是 比 FlowLayout 


4) GridLayout: 将 整个 容器 划分 成 一 定 的 行 和 一 定 的 列 ， 可 以 指定 控件 放 在 茶 行 某 


列 上 。 


5) GridBagLayout: GridBagLayout 是 Swing 中 最 灵活 也 是 最 复杂 的 布局 管 


时 器， 可 对 控 


件 在 容器 中 的 位 置 进行 比较 灵活 的 调整 。 


通过 上 


的 分 析 可 知 ， 选 项 B 正确 。 


所 以 ， 本 题 的 答案 为 B。 


40. 答案 : 


C。 


分 析 : 本 题 考 察 的 是 对 tomcat 配置 的 理解 。 

一 般 情况 下 ， 配 置 虚拟 目录 的 方法 是 ; 

在 tomcat\conf 下 serverxml 中 找到 <Host name="localhost" appBase="webapps" unpackWARs= 
"true" autoDeploy="true" xmlValidation="false" xmlNamespaceAware="false"> </Host>， 在 其 中 添 


加 : <Context path=" docBase=" 自 定义 目录 " reloadable="true"></Context>。 
对 于 选项 A, web.xml 可 以 被 看 作 是 JSP 的 一 个 配置 文件 , 其 中 一 个 重要 的 作用 是 


置 Sevlet 的 路 径 。 所 以 ， 选 项 A 错误 。 
对 于 选项 B，index.jsp 一 般 是 一 个 网 站 的 首页 ， 不 包含 与 tomcat 相关 的 配置 信息 。 所 以 ， 


选项 B 错误 。 


所 以 ， 本 题 的 答案 为 C。 


41 . 


答案 


: D。 


分 析 : 本 题 考察 的 是 HTML 知识 。 
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本 题 中 ， 对 于 选项 A，RADIO 为 单 选 按钮 控件 标签 ， 是 表单 标记 。 所 以 ， 选 项 A 错误 。 

对 于 选项 B，INPUT 表示 Form 表单 中 的 一 种 输入 对 象 ， 其 又 随 Type 类 型 的 不 同 而 分 文 
本 输入 框 、 密 码 输入 框 、 单 选 / 复 选 框 及 提交 / 重 置 按 钮 等 ， 是 表单 标记 。 所 以 ， 选 项 B 错误 。 

对 于 选项 C，CHECKBOX 为 多 选 复 选 框 标 签 ， 是 表单 标记 。 所 以 ， 选 项 C 错误 。 

对 于 选项 D，TR 是 表 中 的 行 标 签 ， 不 属于 表单 标记 。 所 以 ， 选 项 D 正确 。 

所 以 ， 本 题 的 答案 为 D。 

42. 答案 : C。 

分 析 : 本 题 考 察 的 是 JSP Web 知识 。 

response 对 和 象 所 提供 的 方法 有 如 下 几 类 : 

(1) 设 定 响应 头 的 方法 


void addCookie(Cookie cookie) 新 增 cookie 

void addDateHeader(String name, long date) 新 增 long 类 型 的 值 到 name 响应 头 
void addHeader(String name, String value) 新 增 String 类 型 的 值 到 name 响应 头 
void addIntHeader(String name, int value) 新 增 int 类 型 的 值 到 name 响应 头 
void setDateHeader(String name, long date) 指定 long 类 型 的 值 到 name 啊 应 头 
void setHeader(String name, String value) 指定 String 类 型 的 值 到 name 响应 头 
void setIntHeader(String name, int value) 指定 int 类 型 的 值 到 name 响应 头 


判断 指定 名 字 的 HTTP 文件 头 是 否 已 
经 存在 ， 然 后 返回 真 假 布尔 值 


boolean containsHeader(String name ) 


(2) 设 定 响 应 状态 码 的 方法 


void sendError(int sc) 传送 状态 码 (status code) 

void sendError(int sc, String msg) 传送 状态 码 和 错误 信息 

void setStatus(int sc) 设 定 状 态 码 

(3) 用 来 URL 重 写 Crewriting) 的 方法 

String encodeRedirectURL(String url) 对 使 用 sendRedirect0 方 法 的 URL 予以 编码 
(4) 设置 重 定向 

sendRedirectO 设置 重 定向 页 面 


(5) 设置 不 同 浏览 器 对 应 的 数据 

setContentType(String contentTypestr): 使 客户 端 浏览 器 区 分 不 同 种 类 的 数据 ， 并 根据 不 同 
的 MIME (Multipurpose Internet Mail Extensions， 多 用 途 互 联网 邮件 扩展 类 型 ) 调 用 浏览 器 内 
不 同 的 程序 艇 入 模块 来 处 理 相 应 的 数据 。 

所 以 ， 选 项 C 正确 。 

所 以 ， 本 题 的 答案 为 C。 

43. 答案 : B。 

分 析 : 本 题 考察 的 是 对 Servlet 所 在 包 的 掌握 情况 。 

对 于 选项 A，java.sql.* 包 中 主要 包含 一 些 访问 数据 库 相 关 的 接口 ， 不 是 编写 Servlet 必须 
导入 的 包 。 所 以 ， 选 项 A 错误 。 
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对 于 选项 B，java.servlet.* 包 中 主要 包含 与 Servlet 相关 的 接口 ， 是 编写 Servlet 必须 导 
的 包 。 所 以 ， 选 项 B 正确 。 

对 于 选项 C，java.util.* 包 中 主要 包含 容器 相关 的 接口 ， 不 是 编写 Servlet 必须 导入 的 包 。 
所 以 ， 选 项 C 错误 。 

对 于 选项 D，java.io.* 主 要 包含 IO 流 读 取 相关 的 类 库 。 所 以 ， 选 项 DD 错误 。 

所 以 ， 本 题 的 答案 为 B。 

44. 答案 : C。 

分 析 : 本 题 考察 的 是 对 SQL 语句 的 理解 。 

SQL 语言 可 以 分 为 四 大 类 : 数据 定义 语言 DDL (Data Definition Language )、 数 据 查 询 语 
言 DQL (Data Query Language )、 数 据 操纵 语言 DML (Data Manipulation Language) 及 数据 
室 制 语言 DCL (Data Control Language )。 

1) 数据 定义 语言 用 来 建立 、 修 改 和 删除 数据 库 中 的 对 象 〈 包 括 表 、 视 图 和 索引 等 )。 

2) 数据 查询 语言 主要 用 来 检索 数据 库 ， 主 要 是 指 select 语句 。 

3) 数据 操纵 语言 用 来 改变 数据 库 中 的 数据 ， 主 要 包含 insert、update 和 delete 语句 。 

4) 数据 控制 语言 用 于 对 数据 库 的 访问 ， 例 如 ， 给 用 户 授予 访问 权限 (GRANT)、 取 消 用 
户 访问 权限 。 

通过 上 面 分 析 可 知 ， 选项 A 和 选项 B 属于 SQL 语句 的 子 类 ,所 以 , 选项 A 与 选项 
B 错误 。 选 项 DD 的 数据 插入 语言 也 属于 数据 操作 语言 的 一 种 ， 因 此 ， 它 也 是 SQL 语句 
的 子 类 ， 所 以 ， 选 项 D 错误 。 对 于 选项 C， 事 务 控制 语言 不 属于 SQL 语句 的 子 类 ， 所 
以 ， 选 项 C 正确 。 

所 以 ， 本 题 的 答案 为 C。 

45. 答案 ， A。 

分 析 : 本 题 考 察 的 是 对 内 部 类 的 理解 。 

在 Java 语言 中 ， 可 以 把 一 个 类 定义 到 另外 一 个 类 的 内 部 ， 在 类 里 面 的 这 个 类 就 叫 作 内 部 
类 ， 外 面 的 类 叫 作 外 部 类 。 在 这 种 情况 下 ， 这 个 内 部 类 可 以 被 看 成 外 部 类 的 一 个 成 员 《〈 与 类 
的 属性 和 方法 类 似 )。 还 有 一 种 类 被 称 为 顶层 〈Top-level) 类 ， 指 的 是 类 定义 代码 不 髓 套 在 其 
他 类 定义 中 的 类 。 

内 部 类 主要 有 以 下 四 种 : 静态 内 部 类 〈Static Inner Class)、 成 员 内 部 类 (Member Inner 
Class)、 局 部 内 部 类 (Local Inner Class) 和 匿名 内 部 类 (Anonymous Inner Class)。 它 们 的 定 
义 方法 如 下 : 


ar 


class outerClass 


{ 
static class innerClass{} // 静 态 内 部 类 
} 
class outerClass 
{ 


class innerClass{} /成 员 内 部 类 普通 内 部 类 ) 


class outerClass 


{ 
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public void menberFunction() 


{ 


class innerClass { 
}V 局 部 内 部 类 


} 


} 


public class MyFrame extends Frame 
{/ 外 部 类 
public MyFrame() 
{ 
addWindowListener(new WindowA dapter() 
{// 匿名 内 部 类 
public void windowClosing(WindowEvent e) 


{ 


dispose(); 
System.exit(0); 


= 一 


); 
} 


态 内 部 类 是 指 被 声明 为 static 的 内 部 类 ， 它 可 以 不 依赖 于 外 部 类 实例 而 被 实例 化 ， 而 
通常 的 内 部 类 需要 在 外 部 类 实例 化 后 才能 实例 化 。 静 态 内 部 类 不 能 与 外 部 类 有 相同 的 
名 字 , 不 能 访问 外 部 类 的 普通 成 员 变 量 ， 只 能 访问 外 部 类 中 的 静态 成 员 和 静态 方法 〈 包 
括 私 有 类 型 )。 

一 个 静态 内 部 类 ， 如 果 去 反 “static” 关 键 字 ， 就 成 为 成 员 内 部 类 。 成 员 内 部 类 为 非 静态 
内 部 类 ， 它 可 以 自由 地 引用 外 部 类 的 属性 和 方法 ， 无 论 这 些 属性 和 方法 是 静态 的 还 是 非 静 态 
的 。 但 是 它 与 一 个 实例 绑 定 在 了 一 起 ， 不 可 以 定义 静态 的 属性 和 方法 。 只 有 在 外 部 的 类 被 实 
例 化 后 ， 这 个 内 部 类 才能 被 实例 化 。 需 要 注意 的 是 ， 非 静态 内 部 类 中 不 能 有 静态 成 员 。 

局 部 内 部 类 指 的 是 定义 在 一 个 代码 块 内 的 类 ， 它 的 作用 范围 为 其 所 在 的 代码 块 ， 是 内 部 
类 中 最 少 使 用 到 的 一 种 类 型 。 局 部 内 部 类 像 局 部 变量 一 样 ， 不 能 被 public、protected、private 
以 及 static 修饰 ， 只 能 访问 方法 中 定义 为 final 类 型 的 局 部 变量 。 对 一 个 静态 内 部 类 ， 去 掉 其 
声明 中 的 “static” 关 键 字 ， 将 其 定义 移入 其 外 部 类 的 静态 方法 或 静态 初始 化 代码 段 中 就 成 为 
局 部 静态 内 部 类 。 对 一 个 成 员 类 ， 将 其 定义 移入 其 外 部 类 的 实例 方法 或 实例 初始 化 代码 中 就 
成 为 局 部 内 部 类 。 局 部 静态 内 部 类 与 静态 内 部 类 的 基本 特性 相同 。 局 部 内 部 类 与 内 部 类 的 基 
本 特性 相同 。 

匿名 内 部 类 是 一 种 没有 类 名 的 内 部 类 ， 不 使 用 关键 字 class、extends 和 implements， 没 有 
构造 方法 ， 它 必须 继承 〈extends) 其 他 类 或 实现 其 他 接口 。 匿 名 内 部 类 的 一 般 好 处 是 代码 更 
加 简洁 、 紧 次， 但 带 来 的 问题 是 易 读 性 下 降 。 它 一 般 应 用 于 GUI (Graphical User Interface， 
图 形 用 户 界 面 ) 编程 中 实现 事件 处 理 等 。 
对 于 本 题 而 言 ， 它 是 一 个 普通 的 内 部 类 ， 这 个 内 部 类 必须 在 外 部 类 实例 化 以 后 才能 实例 
化 ， 因 此 ， 对 于 选项 A 而 言 ，someOuterMethod 是 Outer 的 实例 方法 ， 可 以 访问 Inner 类 ， 因 


于 


UD 


oS 
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为 在 调用 someouterMethod 的 时 候 ， 外 部 类 一 定 是 已 经 被 实例 化 了 ， 所 以 ， 选 项 A 正确 。 选 
项 B、 选 项 C 和 选项 D 都 试图 在 没有 实例 化 外 部 类 的 情况 下 直接 去 实例 化 内 部 类 ， 因 此 ， 是 
错误 的 。 如 果 把 这 个 内 部 类 改 成 静态 内 部 类 ， 那 么 ， 选 项 B、 选 项 C 和 选项 DD 就 都 正确 。 

所 以 ， 本 题 的 答案 为 A。 

二 、 多 选 题 

1. 答案 : A、D。 

分 析 : 本 题 考察 的 是 对 final 方法 的 理解 。 

当 一 个 方法 声明 为 final 时 ， 该 方法 不 允许 任何 子 类 覆盖 这 个 方法 ， 但 子 类 仍然 可 以 使 用 
这 个 方法 。 另 外 ， 还 有 一 种 被 称 为 inline〈 内 联 ) 的 机 制 ， 当 调用 一 个 被 声明 为 final 的 方法 
时 ， 直 接 将 方法 主体 插入 到 调用 处 ， 而 不 是 进行 方法 调用 《类似 于 C++ 语言 中 的 内 联 inline)， 
这 样 做 能 提高 程序 的 效率 。 

从 上 面 分 析 可 知 ， 本 题 的 答案 为 A、D。 

对 于 选项 B，void 与 final 的 位 置 写 反 了 ， 因 此 ， 语 法 错误 。 所 以 ， 选 项 B 错误 。 

对 于 选项 C， 没 有 被 final 修饰 ， 因 此 ， 写 法 错误 。 所 以 ， 选 项 C 错误 。 

对 于 选项 E， 被 声明 为 abstract 的 方法 不 能 被 final 修饰 ， 因 为 被 abstract 修饰 的 方法 是 抽 
象 方法 , 没有 方法 体 ， 只 有 子 类 实现 了 这 个 方法 才 有 意义 ,而 被 final 修饰 的 方法 不 能 被 继承 ， 
这 两 个 关键 字 是 矛盾 的 ， 因 此 ， 不 能 同时 使 用 。 所 以 ， 选 项 EE 错误 。 

所 以 ， 本 题 的 答案 为 A、D。 

2. 答案 : A、D。 

分 析 : 本 题 考察 的 是 JSP 注释 知识 。 

JSP 有 两 种 注释 方式 : 

1) 显 式 注释 :“<!-- 注 释 内 容 -->”。 因 为 显 式 注释 会 被 JSP 引擎 解释 ， 在 客户 端 HTML 
文件 的 源 代码 中 生成 同样 的 注释 信息 ， 但 不 会 在 HTML 页 面 上 显示 。 所 以 ， 选 项 A 正确 。 

2) 隐 式 注释 : 可 以 使 用 Java 语言 中 的 “//”“/*…*/” 以 及 JSP 中 自己 的 注释 :“<%-- 
注释 内 容 --%>” 隐 式 注释 和 显 式 注释 一 样 不 能 在 JSP 页 面 显示 ， 但 是 隐 式 注释 不 能 在 客户 端 
HTML 文件 的 源 代 码 中 生成 同样 的 注释 信息 。 所 以 ， 选 项 D 正确。 

所 以 ， 本 题 的 答案 为 A、D。 

3. 答案 : A、D。 

分 析 : 本 题 考 察 的 是 SQL 知识 。 

对 于 选项 A，ORDER BY avg_grade 是 采用 默认 的 排序 方式 对 平均 成 绩 进行 排序 。 所 以 ， 
选项 A 正确 。 

对 于 选项 B 与 选项 C，GROUP BY 只 会 与 sum、count、avg 等 聚合 函数 共同 使 用 来 完成 
某 种 统计 功能 ， 不 能 单独 使 用 。 所 以 ， 选 项 B、 选 项 C 不 正确 。 

对 于 选项 D， 采 用 asc 指定 了 碍 询 结果 对 平均 成 绩 进 行 升序 排列 。 所 以 ， 选 项 D 正确 。 

所 以 ， 本 题 的 答案 为 A、D。 

4. 答案 : A、B、C。 

分 析 : 本 题 考察 的 是 JSP 知识 。 

对 于 选项 A，application 代表 与 整个 Web 应 用 程序 相关 的 对 象 和 属性 ， 这 实质 上 是 跨越 
多 个 Web 应 用 程序 ， 包 括 多 个 页 面 、 请 求 和 会 话 的 一 个 全 局 作用 域 ， 因 此 ， 可 以 用 作 JSP 之 
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间 进 行 通信 。 所 以 ， 选 项 A 正确 。 

对 于 选项 B，session 代表 与 用 于 某 个 Web 客户 端的 一 个 用 户 体验 相关 的 对 象 和 属性 ， 一 
个 Web 会 话 经 常会 跨越 多 个 客户 端 请 求 ， 因 此 ， 可 以 用 作 JSP 之 间 进 行 通信 。 所 以 ， 选 项 B 
正 看 


对 于 选项 C，pageContext 对 象 代表 该 JSP 页 面 上 下 文 ， 使 用 该 对 象 可 以 访问 页 面 中 的 共 
享 数据 ， 因 此 ， 可 以 用 作 JSP 之 间 进 行 通信 。 所 以 ， 选 项 C 正确 。 
对 于 选项 D，cookie 是 在 HTTP 协议 下 ， 服 务 器 或 脚本 可 以 维护 客户 工作 站 上 信 生 
种 方式 。 它 是 由 Web 服务 器 保存 在 用 户 浏览 器 上 的 小 文件 ， 可 以 包含 有 关 用 户 的 信息 《如 身 

份 识别 号 码 、 密 码 等 信息 )， 不 能 用 作 JSP 之 间 的 通信 。 所 以 ， 选 项 DD 错误 。 

所 以 ， 本 题 的 答案 为 A、B、C。 

5. 答案 A、B。 

分 析 : 本 题 考 察 的 是 对 接口 定义 的 理解 。 

接口 就 是 指 一 个 方法 的 集合 ， 接 口中 的 所 有 方法 都 没有 方法 体 ， 在 Java 语言 中 ， 接 口 是 
通过 关键 字 interface 来 实现 的 。 接 口中 定义 的 成 员 变 量 默认 为 public static final， 只 能 够 有 静 
态 的 不 能 被 修改 的 数据 成 员 , 而 且 ， 必须 给 其 赋 初 值 ， 其 所 有 的 成 员 方法 都 是 public、abstract 
的 ， 而 且 只 能 被 这 两 个 关键 字 修 饰 。 
显然 ， 选 项 A 和 选项 B 是 正确 的 。 

对 于 选项 C， 接 口中 的 方法 不 能 被 final 修饰 。 因 此 ， 选 项 C 错误 。 

对 于 选项 D， 接 口中 的 方法 不 能 被 static 修饰 。 因 此 ， 选 项 DD 错误 。 

对 于 选项 下 ， 接 口中 的 方法 不 能 被 protected 修饰 。 因 此 ， 选 项 E 错误 。 

所 以 ， 本 题 的 答案 为 A、B。 

6. 答案 ， C、D、E。 

分 析 : 本 题 考 察 的 是 数组 知识 。 

在 Java 语言 中 ， 二 维 数组 有 以 下 三 种 声明 的 方法 : 

1) type arrayName[][]; 

2) type[][] arrayName; 

3) type[] arrayName[]; 

需要 注意 的 是 ， 在 声明 二 维 数 组 时 ， 方 括号 必须 为 空 。 

二 维 数组 也 可 以 使 用 初始 化 列表 的 方式 来 进行 初始 化 ， 它 的 一 般 形 式 如 下 : 

type arrayName[|[|={{cl11,c12,c13...},{c21,c22,c23...},{c31,c32,c33...}...}; 

也 可 以 通过 new 关键 字 来 给 数组 申请 存储 空间 ， 使 用 方法 如 下 所 示 : 

type arrayname[][]=new type[ 行 数 ][ 列 数 ]; 

与 C/C++ 语言 不 同 的 是 ， 在 Java 语言 中 ， 二 维 数组 的 第 二 维 的 长 度 可 以 不 同 。 假 如 要 定 
义 一 个 二 维 数组 ， 该 二 维 数组 有 两 行 ， 第 一 行 有 两 列 ， 第 二 行 有 三 列 ， 定 义 方法 如 下 : 
1) int[][] arr= {{1,2},{3,4,5}}; 
2) int[][] a =new int[2][]; 

a[0]=new int[]{1,2}; 

a[l]=new int[] {3,4,5}; 
对 于 选项 A， 在 申请 空间 的 时 候 没 有 指定 行 数 与 列 数 。 因 此 ， 选 项 A 错误 。 
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对 于 选项 B， 在 二 维 数组 声明 的 部 分 不 能 写 行 数 与 列 数 。 因 此 ， 选 项 B 错误 。 

选项 C、 选 项 D 与 选项 EE 的 描述 方式 都 是 正确 的 。 

所 以 ， 本 题 的 答案 为 C、D、 了 E。 

7. 答案 : B、C。 

分 析 : 本 题 考 察 的 是 Java 数据 类 型 的 知识 。 

Java 语言 一 共 提 供 了 8 种 原始 的 数据 类 型 (byte、short、int、long、float、double、char 
和 boolean)， 这 些 数 据 类 型 不 是 对 象 ， 而 是 Java 语言 中 不 同 于 类 的 特殊 类 型 ， 这 些 基本 类 型 
的 数据 变量 在 声明 之 后 就 会 立刻 在 栈 上 分 配 内 存 空间 。 除 了 这 8 种 基本 的 数据 类 型 外 ， 其 他 
的 类 型 都 是 引用 类 型 (例如 类 、 接 口 和 数组 等 )， 引 用 类 型 类 似 于 C++ 语言 中 的 引用 或 指针 的 
概念 ， 它 以 特殊 的 方式 指向 对 象 实体 ， 这 类 变量 在 声明 时 不 会 被 分 配 内 存 空 间 ， 只 是 存储 了 
一 个 内 存 地 址 而 已 。 

此 外 ，Java 语言 还 提供 了 对 这 些 原 始 数 据 类 型 的 包装 类 (字符 类 型 Character， 布 尔 类 型 
Boolean， 数 值 类 型 Byte、Short、Integer、Long、Float 及 Double)。 

包装 类 型 和 原始 类 型 有 许多 不 同 点 :原始 数据 类 型 在 传递 参数 时 都 是 按 值 传递 ， 而 包装 
类 型 是 按 引 用 传递 的 ， 当 包装 类 型 和 原始 类 型 用 作 某 个 类 的 实例 数据 时 ， 对 象 引 用 实例 变量 
的 默认 值 为 null, 而 原始 类 型 实例 变量 的 默认 值 与 它们 的 类 型 有 关 , 例如 数字 是 0 (包括 byte、 
short、int、long 等 类 型 )，boolean 是 false， 浮 点 (包括 float、double) 是 0.0f。 

通过 以 上 分 析 可 知 ，Boolean 和 Double 是 基本 数据 类 型 boolean 和 double 的 包装 类 ， 而 
不 是 Java 语言 的 简单 数据 类 型 ， 所 以 ， 选 项 B 与 选项 C 错误 。 

所 以 ， 本 题 的 答案 为 B、C。 

8. 答案 : A、B。 

分 析 : 本 题 考 察 的 是 数组 知识 。 

在 Java 语言 中 ， 一 维 数组 的 声明 方式 为 

type arrayName[] 或 type[] arrayName 

其 中 ，type 既 可 以 是 基本 的 数据 类 型 ， 也 可 以 是 类 ，arrayName 表示 数组 的 名 字 ，[0] 用 来 
表示 这 个 变量 的 类 型 为 一 维 数组 。 与 C/C++ 语言 不 同 的 是 ， 在 Java 语言 中 ， 数 组 被 创建 后 会 
根据 数组 存放 的 数据 类 型 初始 化 成 对 应 的 初始 值 〈 例 如 ，int 类 型 会 初始 化 为 0， 对 象 会 初始 
化 为 null)。 另 外 一 个 不 同 之 处 是 ，Java 数组 在 定义 时 ， 并 不 会 给 数组 元 素 分 配 存储 空间 ， 因 
此 ,口中 不 需要 指定 数组 的 长 度 。 对 于 使 用 上 面 方式 定义 的 数组 在 使 用 时 还 必须 为 之 分 配 空间 ， 
分 配方 法 为 

arrayName = new type[arraySize]; 。”// arraySize 表示 数组 的 长 度 

对 于 选项 A， 首 先 声 明了 一 个 字符 串 数组 类 型 的 变量 a， 这 个 数组 的 大 小 为 5， 接着 给 这 
5 个 数组 元 素 都 初始 化 为 “”， 在 此 过 程 中 生成 了 5 个 空 字 符 串 。 所 以 ， 选 项 A 正确 。 

对 于 选项 B， 声 明了 一 个 大 小 为 5 的 字符 串 数 组 ， 并 给 每 个 元 素 都 初始 化 为 “”， 在 此 过 
程 中 也 生成 了 5 个 空 字 符 串 。 所 以 ， 选 项 B 正确 。 

对 于 选项 C， 只 是 声明 了 一 个 大 小 为 5 的 字符 串 数组 ， 并 没有 对 字符 串 进行 初始 化 ， 
此 ， 字 符 串 的 值 都 为 null， 而 不 是 “。 所 以 ， 选 项 C 错误 。 

对 于 选项 D， 声 明了 一 个 大 小 为 5 的 字符 串 数 组 ， 但 是 数组 中 每 个 元 素 都 被 初始 化 为 
null， 在 此 过 程 中 没有 生成 任何 字符 串 。 所 以 ， 选 项 DD 错误 。 
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所 以 ， 本 题 的 答案 为 A、B。 

9. 答案 : B、C、D。 

分 析 : 本 题 考察 的 是 Java 基本 类 型 的 知识 。 

在 Java 语言 中 ， 除 了 8 种 基本 数据 类 型 ， 其 他 的 类 型 都 是 对 象 ， 因 此 ， 选 项 A 正确 ， 选 
项 B 错误 。 

对 于 选项 C， 写 法 有 语法 错误 ， 正 确 的 写法 为 int number[]={1,2,3,4,5}。 所 以 ， 选 项 C 
背 误 。 

对 于 选项 D， 数 组 的 大 小 是 在 定义 时 确定 的 ， 一 旦 确定 后 就 不 能 任意 改变 了 。 所 以 ， 选 
项 DD 错误 。 

所 以 ， 本 题 的 答案 为 B、C、D。 

10. 答案 : A、C、D。 

分 析 : 本 题 考察 的 是 对 接口 的 理解 。 
| 于 接口 的 目的 就 是 让 其 他 的 类 来 实现 的 ， 如 果 没 有 被 实现 ， 接 口 就 没有 存在 的 意义 ， 
因此 ， 它 不 能 被 private 和 final 修饰 ， 否 则 无 法 被 实现 。 同 理 ， 接 口 也 不 能 被 static 修饰 。 所 
以 ， 选 项 A、 选项 C 与 选项 D 正确 。 

所 以 ， 本 题 的 答案 为 A、C、D。 

11. 答案 : A、C、D。 

分 析 : 本 题 考察 的 是 对 类 方法 的 理解 。 

类 方法 是 指 被 static 修饰 的 方法 ， 这 种 方法 不 需要 创建 对 象 就 可 以 被 调用 ，static 方法 中 
不 能 使 用 this 和 super 关键 字 ， 不 能 调用 非 static 方法 ， 只 能 访问 所 属 类 的 静态 成 员 变 量 和 成 
员 方 法 ， 因 为 当 static 方法 被 调用 时 ， 这 个 类 的 对 象 可 能 还 没 被 创建 ， 即 使 已 经 被 创建 了 ， 也 
无 法 确定 调用 哪个 对 象 的 方法 。 同 理 ，static 方法 也 不 能 访问 非 static 类 型 的 变量 。 

对 于 选项 A， 在 类 方法 中 不 可 用 this 来 调用 本 类 的 类 方法 。 所 以 ， 选 项 A 错误 。 

对 于 选项 B， 在 类 方法 中 调用 本 类 的 类 方法 时 ， 可 直接 调用 。 所 以 ， 选 项 B 正确 。 

对 于 选项 C， 在 类 方法 中 可 以 通过 实例 化 一 个 对 象 来 间接 调用 实例 方法 ， 但 是 不 能 直接 
。 因 此 ， 说 绝对 不 能 调用 是 不 正确 的 。 所 以 ， 选 项 C 错误 。 

对 于 选项 D， 在 类 方法 中 ， 不 仅仅 能 调用 本 类 的 方法 ， 还 能 调用 父 类 的 类 方法 。 所 以 ， 
选项 DD 错误 。 

所 以 ， 本 题 的 答案 为 A、C、D。 

12. 答案 : B、D。 

分 析 : 本 题 考察 的 是 构造 方法 知识 。 

对 于 选项 A， 默 认 构 造 器 的 修饰 符 只 与 当前 类 的 修饰 符 有 关 。 如 果 类 B 是 public 的 ， 那 
么 默认 构造 方法 也 是 public 的 。 如 果 B 类 是 默认 的 访问 权限 ， 则 构造 方法 与 它 相同 ， 也 是 默 
认 访 问 权 限 。 因 此 ， 选 项 A 错误 。 

对 于 选项 B， 编 译 器 提供 的 默认 构造 方法 是 没有 参数 的 。 因 此 ， 选 项 B 正确 。 

对 于 选项 C， 在 Java 语言 中 ， 没 有 this0 这 种 写法 。 因 此 ， 选 项 C 错误 。 

对 于 选项 D， 在 继承 中 ， 子 类 会 默认 调用 父 类 的 无 参数 的 构造 方法 。 因 此 ， 选 项 D 
正确 。 

所 以 ， 本 题 的 答案 为 B、D。 
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13. 答案 : A、C、D。 

分 析 : 本 题 考察 的 是 Java 语言 标识 符 知 识 。 

14. 答案 : A、D、E、F。 

分 析 : 本 题 考 察 的 是 对 Java 异常 的 理解 。 

异常 是 指 程序 运行 时 《〈 非 编译 时 ) 所 发 生 的 非 正 常情 况 或 错误 ， 当 程序 违反 了 语义 规则 
时 ，JVM 就 会 将 出 现 的 错误 表示 为 一 个 异常 并 抛 出 。 这 个 异常 可 以 在 catch 程序 块 中 进行 捕 
获 ， 然 后 进行 处 理 。 而 异常 处 理 的 目的 则 是 为 了 提高 程序 的 安全 性 与 健壮 性 。 

Java 语言 把 异常 当 作 对 象 来 处 理 ， 并 定义 了 一 个 基 类 (java.lang.Throwable〉 作 为 所 有 异 
常 的 超 类 。 在 Java API 中 ， 已 经 定义 了 许多 异常 类 ， 这 些 异 常 类 分 为 两 大 类 ，Error〈 错 误 ) 
和 Exception (异常 )。 
违反 语义 规则 包括 以 下 两 种 情况 : 一 种 情况 是 Java 类 库 内 置 的 语义 检查 ， 例 如 ， 当 数 
组 下 标 越 界 时 ， 会 引发 IndexOutOfBoundsException， 而 当 访 问 null 的 对 象 时 ， 会 引发 
NullPointerException; 另 一 种 情况 是 Java 语言 允许 开发 人 员 扩 展 这 种 语义 检查 ， 开 发 人 员 可 
以 创建 自己 的 异常 类 (所 有 的 异常 都 是 Java.lang.Thowable 的 子 类 ), 并 自由 选择 在 何 时 用 throw 
关键 字 抛 出 异常 。 

对 于 本 题 而 言 ，Throwable 为 异常 处 理 的 基 类 ，Error、Exception 和 RuntimeException 都 
是 Throwable 的 子 类 ， 因 此 ， 都 能 使 用 throw 抛 出 。 所 以 ， 选 项 A、 选 项 D、 选 项 EE 与 选项 F 
正确 


所 以 ， 本 题 的 答案 为 A、D、E、F。 
15. 答案 : B、C。 
分 析 : 本 题 考察 的 是 对 Servlet 包 的 理解 。 
Servlet 和 ServletContext 是 接口 ， 只 有 GenericServlet 和 ServletException 是 类 。 所 以 ， 选 
项 B 与 选项 C 正确 。 
所 以 ， 本 题 的 答案 为 B、C。 
16. 答案 : C、E。 
分 析 : 本 题 主要 考察 对 履 盖 〈Override) 的 理解 。 
履 盖 〈Override) 是 指派 生 类 函数 覆盖 基 类 方法 ， 履 盖 一 个 方法 并 对 其 重 写 ， 以 达到 不 同 
的 作用 。 在 使 用 履 盖 时 ， 需 要 注意 以 下 几 点 ; 
1) 派生 类 中 的 歼 盖 方法 必须 要 和 基 类 中 被 覆盖 的 方法 有 相同 的 方法 名 和 参数。 
2) 派生 类 中 的 覆盖 方法 的 返回 值 必须 和 基 类 中 被 覆盖 的 方法 的 返回 值 相同 。 
3) 基 类 中 被 覆盖 的 方法 不 能 为 private， 和 否则 ， 其 子 类 只 是 定义 了 一 个 方法 ， 并 没有 对 其 


窗 盖 


4) 子 类 方法 不 能 缩小 父 类 方法 的 访问 权限 。 
5) 子 类 方法 不 能 抛 出 比 父 类 方法 更 多 的 异常 。 
对 于 选项 A， 与 父 类 的 方法 名 和 参数 都 相同 ， 但 是 返回 值 丰 用， 所 以 ， 语 法 错误 。 因 此 ， 
选项 A 错误 。 同 理 ， 选 项 B 错误 。 

对 于 选项 C， 这 个 方法 与 父 类 方法 有 不 同 的 参数 ， 因 此 ， 类 Y 会 从 父 类 继承 工 方法 ， 这 
个 选项 定义 的 方法 可 以 看 成 类 的 重 载 类 。 因 此 ， 选 项 C 正确 。 
对 于 选项 D， 父 类 方法 为 public， 这 个 选项 定义 的 方法 为 private 缩小 了 访问 权限 。 因 此 ， 
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选项 D 错误 。 


真题 详解 篇 


对 于 选项 E, 方法 定义 完全 符合 覆盖 的 要 求 ， 虽 然 返 回 值 类 型 为 X, 由 于 Y 为 X 的 子 类 ， 


所 以 ， 本 题 的 答案 为 C、E。 
17. 答案 : B、C、D。 


因此 ， 返 回 Y 的 实例 化 对 象 也 是 正确 的 。 因 此 ， 选 项 E 正确 。 


分 析 : 本 题 考察 的 是 对 parseInt 方法 的 理解 。 


使 用 parseInt0 方 法 用 于 解析 参数 中 的 字符 串 ， 并 返回 对 应 的 整数 , parseXxx0O 是 一 个 静态 


方法 , 可 以 有 一 个 或 两 个 参数 。Ingeger 类 的 parseInt 方法 会 抛 出 NumberFormatException 异常 
( 当 传 入 的 参数 不 能 够 被 转 成 int 的 时 候 ), 因此 , 一 般 情况 下 都 会 把 对 这 个 方法 的 调用 放 到 try 


catch 之 间 。 所 以 ， 选 项 B、 选 项 C 与 选项 
所 以 ， 本 题 的 答案 为 B、C、D。 
18. 答案 : B、G。 


D 正确 。 


分 析 : 本 题 考 察 的 是 对 JSP 中 动作 的 理解 。 
jsp:getProperty 标签 用 于 获取 被 加 载 到 当前 页 面 中 的 JavaBean 中 某 个 属性 的 值 , 它 


的 格式 为 


Sjsp:getProperty name=? property=? /> 


其 中 ，name: JavaBean 的 对 象 名 ， 用 于 指定 从 哪个 JavaBean 中 获取 属性 值 ，property: 
JavaBean 中 的 属性 名 ， 用 于 指定 获取 JavaBean 中 的 哪个 属性 值 。 当 JavaBean 中 的 属性 名 为 


abc 时 ， 获 取 该 属性 值 的 方法 名 为 getAbc0 


o 


对 于 本 题 而 言 ， 在 选项 D、 选 项 E、 选 项 F 与 选项 G 中 ， 只 有 选项 G 的 写法 是 合理 的 ， 


它 的 功能 是 获取 对 象 YoshiBean 的 size 属性 。 


对 于 选项 A， 一 般 不 推荐 直接 访问 对 象 的 属性 ， 都 是 把 属性 定义 为 私有 的 ， 然 后 提供 公 


有 的 方法 访问 。 如 果 size 被 定义 为 私有 的 ， 


那么 无 法 用 这 种 方式 来 访问 。 


对 于 选项 B， 在 JSP 中 直接 调用 Java 代码 ， 调 用 对 象 YoshiBean 的 getSize 方法 获取 size 


属性 ， 因 此 ， 选 项 B 和 选项 G 是 等 价 的 。 


对 于 选项 C， 一 般 而 言 ， 对 象 获取 属性 的 方法 都 是 类 似 getXXXO0 的 写法 。getProperty 只 
能 被 理解 为 男 外 一 个 方法 ， 与 获取 size 属性 无 关 。 


所 以 ， 本 题 的 答案 为 B、G。 
19. 答案 : B、C、E。 


分 析 : 本 题 考 察 的 是 默认 构造 方法 的 知识 。 


本 题 中 ， 对 于 选项 A， 默 认 构造 方法 就 是 一 个 方法 体 为 空 的 方法 ， 不 实现 任何 功能 。 因 


此 ， 选 项 A 错误 。 


对 于 选项 B， 默 认 构造 方法 会 默认 调用 父 类 无 参数 的 构造 方法 。 因 此 ， 选 项 B 正确 。 


对 于 选项 C， 默 认 构 造 方法 没有 被 显 式 地 用 访问 修饰 符 修饰 ， 所 以 ， 它 与 类 有 相同 的 访 


问 修饰 符 。 因 此 ， 选 项 C 正确 。 


对 于 选项 D， 只 有 当 一 个 类 没有 构造 方法 的 时 候 ， 编 译 器 才 会 提供 一 个 默认 的 构造 方法 。 
如 果 给 类 定义 了 一 个 有 参数 的 构造 方法 ， 此 时 编译 器 也 就 不 会 提供 默认 的 构造 方法 。 因 此 ， 


选项 D 错误 。 


183 


Java 程序 员 面 试 笔试 真题 尼 


对 于 选项 了 ， 当 一 个 类 没有 构造 方法 的 时 候 ， 编 译 器 会 提供 一 个 默认 的 构造 方法 。 因 此 ， 
选项 E 正确 。 

所 以 ， 本 题 的 答案 为 B、C、E。 

20. 答案 : C、D。 

分 析 : 本 题 考 察 的 是 对 Servlet 生命 周期 的 理解 。 
| 于 Servlet 运行 在 容器 中 ,没有 main0 方 法 ， 因 此 ， 整 个 生命 周期 都 是 由 容器 来 控制 的 。 
简单 而 言 ，Servlet 的 生命 周期 只 有 两 个 状态 ， 即 未 创建 状态 与 初始 化 状态 。 这 两 种 状态 的 转 
换 主 要 是 由 三 个 重要 的 方法 来 进行 控制 的 :initO、service0 和 destroy()。 其 中 ,init0 方 法 是 Servlet 
生命 的 起 点 ， 用 于 创建 或 打开 任何 与 Servlet 相关 的 资源 以 及 执行 初始 化 工作 ;service0 方 法 
是 Servlet 中 真正 处 理 客户 端 传 过 来 的 请 求 的 方法 ， 它 根据 HTTP 请 求 方法 (GET、POST 等 ) 
将 请 求 分 发 到 doGet()、doPost(0 等 方法 ; destory0 方 法 释放 任何 在 init0 方 法 中 打开 的 与 Servlet 
相关 的 资源 。 

Servlet 的 状态 变化 如 图 16 所 示 。 


service() 


constructer(),init() SA 
图 16 Servlet 状态 变化 
具体 而 言 ，Servlet 的 生命 周期 可 以 分 为 加 载 、 创 建 、 初 始 化 、 处 理 客 户 请 求 和 外 载 五 个 


阶段 。 

1) 加 载 : 容器 通过 类 加 载 器 使 用 Servlet 类 对 应 的 文件 来 加 载 Servlet。 

2) 创建 : 通过 调用 Servlet 的 构造 方法 来 创建 一 个 Servlet 实例 。 

3) 初始 化 : 通过 调用 Servlet 的 init0 方 法 来 完成 初始 化 工作 ， 这 个 方法 是 在 Servlet 已 被 
创建 但 问 客户 端 提供 服务 之 前 调用 的 ， 需 要 注意 的 是 ，init0 方 法 只 会 被 调用 一 次 。 

4) 处 理 客户 请 求 : Servlet 一 旦 被 创建 后 ， 它 就 可 以 为 客户 端 提供 服务 了 。 每 当 有 新 的 客 
户 请 求 到 来 时 ， 容 器 都 会 创建 一 个 新 的 线程 来 处 理 该 请 求 ， 接 着 会 调用 Servlet 的 service() 方 
法 来 完成 客户 端的 请 求 ， 当 然 ，service() 方 法 会 根据 请 求 的 method 属性 值 的 不 同 ， 决 定 是 调 
用 doGet() 方 法 还 是 调用 doPost(O) 方 法 来 完成 具体 的 响应 。 

5) 介 载 : 容器 在 卸载 Servlet 之 前 需要 调用 destroy0 方 法 ， 让 Servlet 自己 释放 其 占用 的 
系统 资源 ， 一 旦 destroy0 方 法 被 调用 ， 容 器 就 不 会 再 向 这 个 Servlet 发 送 任何 请 求 消 息 了 。 如 
果 容 器 需要 这 个 Servlet， 那 么 就 必须 重新 创建 并 初始 化 一 个 实例 。 需 要 注意 的 是 ，destroy0 
方法 只 会 被 调用 一 次 。 

本 题 中 ，init0 方 法 和 destroy() 方 法 只 调用 一 次 。 所 以 ， 选 项 C 与 选项 DD 正确 。 

所 以 ， 本 题 的 答案 为 C、D。 

三 、 简 答题 

1. 答案 : static 关键 字 主要 有 两 种 作用 : 第 一 ， 为 某 特 定数 据 类 型 或 对 象 分 配 单一 的 存 
储 空间 ， 而 与 创建 对 象 的 个 数 无 关 。 第 二 ， 和 希望 某 个 方法 或 属性 与 类 而 不 是 对 象 关联 在 一 起 ， 
也 就 是 说 ， 在 不 创建 对 象 的 情况 下 就 可 以 通过 类 来 直接 调用 方法 或 使 用 类 的 属性 。 有 具体 而 言 ， 
static 在 Java 语言 中 主要 有 四 种 使 用 情况 : 成 员 变 量 、 成 员 方法 、 代 码 块 及 内 部 类 。 以 下 将 分 
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别 对 这 4 种 情况 进行 介绍 。 
(1) static 成 员 变量 
虽然 Java 语言 中 没有 全 局 的 概念 ， 但 可 以 通过 static 关键 字 来 达到 全 局 的 效果 。Java 类 

提供 了 两 种 类 型 的 变量 : 用 static 关键 字 修饰 的 静态 变量 和 没有 static 关键 字 的 实例 变量 。 吏 

态 变 量 属 于 类 ， 在 内 存 中 只 有 一 个 副本 《所 有 实例 都 指向 同一 个 内 存 地 址 )， 只 要 静态 变量 所 

在 的 类 被 加 载 ， 这 个 静态 变量 就 会 被 分 配 空间 ， 因 此 ， 就 可 以 被 使 用 了 。 对 静态 变量 的 引用 

有 两 种 方式 ， 分 别 为 “类 .静态 变量 ”和 “对 象 .静态 变量 ” 
实例 变量 属于 对 象 ， 只 有 对 象 被 创建 后 ， 实 例 变 量 才 会 被 分 配 空间 ， 才 能 被 使 用 ， 它 在 

内 存 中 存在 多 个 副本 。 只 能 用 “对 象 .静态 变量 ”的 方式 来 引用 。 以 下 是 静态 变量 与 实例 变量 

的 使 用 例子 : 


public class TestAttribute 
{ 
public static int staticInt=0; 
public int nonStaticInt=0; 
public static void main(String[ | args) 
{ 
TestAttribute t=new TestAttribute(); 
System.out.println("t.staticInt="+t.staticInt); 
System.out.println("TestAttribute.staticInt="+TestAttribute.staticInt); 
System.out.println("t.nonStaticInt="+t.nonStaticInt); 
System.out.printIn(" 对 静态 变量 和 实例 变量 分 别 +1"); 
t.staticInt+ 十 ; 
tnongStaticInt+ 十 ; 
TestAttribute tl=new TestAttribute(); 
System.out.println("tl.staticInt="+tl.staticInt); 
System.out.println("TestAttribute.staticInt="+TestAttribute.staticInt); 
System.out.println("tl.nonStaticInt="+t1 .nonStaticInt); 


1 
了 
上 例 的 运行 结果 关 


t.staticInt=0 
TestAttribute.staticInt=0 
t.nonStaticInt=0 

对 静态 变量 和 实例 变量 分 别 +1 
t1.staticInt=1 
TestAttribute.staticInt=1 
tl.nonStaticInt=0 


从 上 例 可 以 看 出 ， 静 态 变量 只 有 一 个 ， 被 类 拥有 ， 上 所 有 的 对 象 都 共享 这 个 静态 变量 ， 而 
实例 对 象 是 与 具体 对 象 相 关 的 。 需 要 注意 与 C++ 语言 不 同 的 是 ， 在 Java 语言 中 ， 不 能 在 方法 
体 中 定义 static 变量 。 

(2) static 成 员 方法 

与 变量 类 似 ，Java 类 同时 也 提供 了 static 方法 与 非 static 方法 。static 方法 是 类 的 方法 , 不 


外 
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需要 创建 对 象 就 可 以 被 调用 ， 而 非 static 方法 是 对 象 的 方法 ， 只 有 对 象 被 创建 出 来 后 才 可 以 被 


使 用 。 


static 方法 中 不 能 使 用 this 和 super 关键 字 ， 不 能 调 月 


日 非 static 方法 ， 只 能 访问 所 属 类 的 静 


态 成 员 变量 和 成 员 方法 ， 因 为 当 static 方法 被 调用 时 ， 这 个 类 的 对 象 可 能 还 没 被 创建 ， 即 使 已 
经 被 创建 了 ， 也 无 法 确定 调用 哪个 对 象 的 方法 。 同 理 ，static 方法 也 不 能 访问 非 static 类 型 的 


变量 。 


static 的 一 个 很 重要 的 用 途 是 实现 单 例 模式 。 单 例 模 式 的 特点 是 该 类 只 能 有 一 个 实例 ， 为 


了 实现 这 一 功能 ， 必 须 隐 藏 类 的 构造 方法 ， 即 把 构造 方法 声明 


为 private， 并 提供 一 个 创建 对 


象 的 方法 。 由 于 构造 对 象 被 声明 为 private， 外 界 无 法 直接 创建 这 个 类 型 的 对 象 ， 只 能 通过 该 


类 提供 的 方法 来 获取 类 的 对 象 ， 要 达到 这 样 的 目的 只 色 


示例 如 下 ; 


EE 把 创建 对 象 的 方法 声明 为 static。 程 序 


class Singleton 

{ 
private static Singleton instance = null; 
private Singleton (全 
public static Singleton getInstance() 


{ 
if( instance == null ) 
{ 
instance = new Singleton (); 
} 


return instance; 


= 一 


} 


用 public 修饰 的 static 变量 和 方法 本 质 上 都 是 全 局 的 ,如 果 在 static 变量 前 用 private 修饰 ， 


则 表示 这 个 变量 可 以 在 类 的 静态 代码 块 或 者 类 的 其 他 前 


类 中 通过 类 名 来 直接 引用 。 
(3 ) static 代码 块 


static 代码 块 〈 静 态 代码 块 ) 在 类 中 是 独立 于 成 员 变 上 


态 成 员 方法 中 使 用 ， 但 是 不 能 在 其 他 


量 和 成 员 函 数 的 代码 块 。 它 不 在 任何 


一 个 方法 体内 ，JVM 在 加 载 类 的 时 候 会 执行 static 代码 块 ， 如果 有 多 个 static 代码 块 ， JVM 将 


会 按 顺 序 来 执行 。static 代码 块 经 常 被 用 来 初始 化 静态 变量 。 需 要 注 


块 只 会 被 执行 一 次 。 如 下 例 所 示 : 


FE 意 的 是 ， 这 些 static 代码 


public class Test 
{ 
private static int a; 
static 
{ 
Test.a = 4; 
System.out.println(a); 


System.out.println("static block is called"); 
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public static void main(String[] args) { 


static block is called 


(4) static 内 部 类 

static 内 部 类 是 指 被 声明 为 static 的 内 部 类 , 它 可 以 不 依赖 于 外 部 类 实例 对 象 而 被 实例 化 ， 
而 通常 的 内 部 类 需要 在 外 部 类 实例 化 后 才能 实例 化 。 静态 内 部 类 不 能 与 外 部 类 有 相同 的 名 字 ， 
不 能 访问 外 部 类 的 普通 成 员 变 量 , 只 能 访问 外 部 类 中 的 静态 成 员 和 静态 方法 (包括 私有 类 型 )。 
如 下 例 所 示 : 


public class Outer 


{ 


static int n = 5; 


static class Inner 


{ 
void accessAttrFromOuter() 
{ 

System.out.println("Inner:Outer.n=" + n); 

} 

} 

public static void main(String[] args) 

{ 
Outer.Inner nest = new Outer.Inner(); 
nest.accessAttrFromOuter(); 

} 


} 


程序 的 运行 结果 六 


Inner:Outer.n=5 


需要 注意 的 是 ， 只 有 内 部 类 才能 被 定义 为 static。 

2. 答案 : 本 题 考察 的 是 对 JSP 和 Servlet 的 理解 。 

相同 点 : JSP 可 以 被 看 作 是 一 个 特殊 的 Servlet, 它 只 不 过 是 对 Servlet 的 扩展 , 只 要 是 JSP 
可 以 完成 的 工作 ， 使 用 Servlet 都 可 以 完成 ， 例 如 ， 生 成 动态 页 面 。 由 于 JSP 页 面 最 终 要 被 转 
换 成 Servlet 来 运行 ， 因 此 ， 处 理 请 求实 际 上 是 编译 后 的 Servlet。 

不 同 点 : GDServlet 的 实现 方式 是 在 Java 语言 中 舱 入 HTML 人 代码， 编写 和 修改 HTML 
非常 不 方便 ， 所 以 ， 它 比较 适合 做 流程 控制 和 业务 处 理 ， 而 JSP 的 实现 方式 为 在 HTML 中 
柑 入 Java 代码 ， 比 较 适 合 页 面 的 显示 。 例如 在 Struts 框架 中 ，Servlet 位 于 MVC 设计 模式 的 
控制 层 ， 而 JSP 位 于 视图 层 。@)Servlet 中 没有 内 置 对 象 ，JSP 中 的 内 置 对 象 都 必须 通过 
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HttpServletRequest 对 象 、HttpServletResponse 对 象 以 及 HttpServlet 对 象 得 到 。 

3. 答案 : switch 能 作用 在 byte 上 ， 不 能 作用 在 long 上 ， 从 Java7 开始 可 以 作用 在 String 上 。 

分 析 : 本 题 考 察 的 是 switch 知识 。 

switch 语句 用 于 多 分 支 选 择 ， 在 使 用 switch(expr) 时 ，expr 只 能 是 一 个 枚 举 常 量 〈 内 部 也 
是 由 整 型 或 字符 类 型 实现 ) 或 一 个 整数 表达 式 ， 其 中 ， 整 数 表达 式 可 以 是 基本 数据 类 型 int 
或 其 对 应 的 包装 类 Integer， 当 然 也 包括 不 同 的 长 度 整 型 ， 例 如 short。 由 于 byte、short 和 char 
都 能 够 被 隐 式 地 转换 为 nt 类 型 ， 因 此 ， 这 些 类 型 以 及 它们 对 应 的 包装 类 型 都 可 以 作为 switch 
的 表达 式 。 但 是 ，long、float、double 及 String 类 型 由 于 不 能 够 隐 式 地 转换 为 int 类 型 ， 因 此 ， 
它们 不 能 被 用 作 switch 的 表达 式 。 如 果 一 定 要 使 用 long、float 或 double 作为 switch 的 参数 ， 
必须 将 其 强制 转换 为 int 型 才 可 以 。 

例如 ， 以 下 对 switch 中 参数 的 使 用 就 是 非法 的 。 


float a = 0.123; 
switch(a) /错误 ! a 不 是 整 型 或 字符 类 型 变量 


{ 


六 


} 
另外 ， 与 switch 对 应 的 是 case 语句 ，case 语句 之 后 可 以 是 直接 的 常量 数值 ， 例 如 1、2， 
也 可 以 是 一 个 常量 计算 式 , 例如 1+2 等 ， 还 可 以 是 final 型 的 变量 (final 变量 必须 是 编译 时 的 
常量 )， 例 如 final inta=0， 但 不 能 是 变量 或 带 有 变量 的 表达 式 ， 例 如 i*2 等 。 当 然 ， 更 不 能 
是 浮 点 型 数 ， 例 如 1.1 或 者 1.2/2 等 。 


switch(form Way) 
{ 


case 2-1 : // 正 确 


case a-2 : // 错 误 


case 2.0 : // 错 误 


} 


随 着 Java 语言 的 发 展 , 在 Java7 中 , switch 开始 支持 String 类 型 了 。 以 下 是 一 段 支 持 String 
类 型 的 示例 代码 : 


public class Test { 


public void test(String str) { 
switch(str) { 

case "hehao": 
System.out.println("hehao"); 
break; 

case "xuepeng": 
System.out.println("xuepeng"); 
break; 


case "yexiangyang": 
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System.out.println("yexiangyang"); 
break; 

default: 
System.out.printin("default"); 


= 一 


} 


从 本 质 上 来 讲 ，switch 对 字符 串 的 支持 ， 其 实 是 int 类 型 值 的 匹配 。 它 的 实现 原理 如 下 : 
通过 对 case 后 面 的 String 对 象 调用 hashCode(0) 方 法 ， 得 到 一 个 int 类 型 的 Hash 值 ， 然 后 用 这 
个 Hash 值 来 唯一 标识 着 这 个 case。 那么 当 匹 配 的 时 候 , 首先 调用 这 个 字符 串 hashCode() 方 法 ， 
获取 一 个 Hash 值 (int 类 型 )， 用 这 个 Hash 值 来 匹配 所 有 的 case， 如 果 没 有 匹配 成 功 ， 说 明 
不 存在 ; 如 果 匹 配 成 功 了 ， 接 着 会 调用 字符 串 的 String.equals0 方 法 进行 匹配 。 由 此 可 以 看 出 ， 
String 变量 不 能 为 null， 同 时 ，switch 的 case 子 句 中 使 用 的 字符 串 也 不 能 为 null。 

4. 答案 : 数据库 连接 是 一 种 非常 珍贵 上 且 有 限 的 资源 ， 尤 其 在 多 用 户 的 网 络 应 用 环境 中 ， 
更 是 如 此 。 对 数据 库 连 接管 理 的 好 坏 会 直接 影响 整个 系统 的 性 能 : 一 是 建立 与 数据 库 的 连接 
是 一 个 耗 时 的 操作 ， 在 页 面 应 用 中 ， 如 果 每 次 用 户 的 请 求 都 需要 建立 新 的 数据 库 连 接 ， 那 么 
响应 时 间 就 会 很 长 ， 严 重 影响 用 户 的 体验 ; 二 是 数据 库 的 连接 个 数 是 有 限制 的 ， 如 果 管 理 不 
好 ， 用 户 经 常 建立 与 数据 库 的 连接 却 态 记 释 放 ， 运 行 时 间 久 了 ， 数 据 库 的 连接 资源 就 会 耗 尽 ， 
当 有 新 的 用 户 需 要 访问 数据 库 的 时 候 ， 此 时 就 需要 等 待 很 长 的 一 段 时 间 直 到 有 用 户 释 放 连 接 
资源 才能 访问 数据 ， 这 对 系统 的 可 用 性 有 着 严重 的 影响 。 因 此 ， 管 理 好 数据 库 的 连接 资源 对 
应 用 系统 尤其 是 页 面 应 用 系统 是 非常 重要 的 。 

数据 库 连 接 池 负责 分 配 、 管 理 并 释放 数据 库 连 接 ， 它 允许 应 用 程序 重复 使 用 一 个 现 有 的 
数据 库 连 接 ， 而 不 再 是 重新 建立 一 个 新 的 数据 库 连接 ， 同 时 ， 它 还 负责 释放 空间 时 间 超 过 最 
大 空间 时 间 的 数据 库 连接 ， 避 免 因为 没有 释放 数据 库 连 接 而 引起 的 数据 库 连 接 遗 漏 。 
在 J2EE 中 , 服务 器 在 启动 的 时 候 会 创建 一 定数 量 的 池 连 接 , 并 一 直 维 持 不 少 于 此 数目 的 
池 连 接 。 当 客户 程序 需要 访问 数据 库 的 时 候 ， 就 可 以 直接 从 池 中 获取 与 数据 库 的 连接 〈 获 取 
一 个 空闲 的 连接 )， 而 不 用 去 创建 一 个 新 的 连接 ， 同 时 标记 该 连接 为 从 状态 。 当 使 用 完毕 后 再 
把 该 连接 标记 为 空闲 状态 ， 这 样 其 他 用 户 就 可 以 使 用 这 个 连接 了 。 如 果 当 前 没有 空闲 的 连接 ， 
那么 服务 器 就 会 根据 配置 参数 在 池 中 创建 一 定数 量 的 连接 。 采 用 这 种 方法 对 数据 库 连 接 进行 
管理 后 可 以 大 幅 提 高 用 户 的 响应 时 间 ， 提 高 运行 效率 。 另 一 方面 ， 为 了 提高 数据 库 操 作 的 性 
沦 ， 数 据 库 连 接 池 会 释放 空间 时 间 超 过 最 大 空 闪 时 间 的 数据 库 连接 ， 以 避免 因为 没有 释放 数 
据 库 连 接 而 引起 的 数据 库 连 接 遗 漏 。 
5. 答案 : 当 使 用 多 线程 访问 同一 个 资源 时 ， 非 常 容 易 出 现 线程 安全 的 问题 〈 例 如 ， 当 多 
个 线程 同时 对 一 个 数据 进行 修改 时 ， 会 导致 某 些 线程 对 数据 的 修改 丢失 )。 因 此 ， 需 要 采用 同 
步 机 制 来 解决 这 种 问题 。Java 主要 提供 了 三 种 实现 同步 机 制 的 方法 : 

(1) synchronized 关键 字 

在 Java 语言 中 ， 每 个 对 象 都 有 一 个 对 象 锁 与 之 相关 联 ， 该 锁 表 明 对 象 在 任何 时 候 上 只 允许 
被 一 个 线程 所 拥有 ， 当 一 个 线程 调用 对 象 的 一 段 synchronized 代码 时 ， 首 先 需要 获取 这 个 锁 ， 
然后 去 执行 相应 的 代码 ， 执 行 结束 后 ， 释 放 锁 。 

synchronized 关键 字 主 要 有 两 种 用 法 (synchronized 方法 和 synchronized 块 )， 此 外 该 关键 
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字 还 可 以 作用 于 静态 方法 、 类 或 某 个 实例 ， 但 这 都 对 程序 的 效率 有 很 大 的 影响 。 
1) synchronized 方法 : 在 方法 的 声明 前 加 入 synchronized 关键 字 。 例 如 : 
public synchronized void mutiThreadAccess(); 

只 要 把 多 个 线程 访问 的 资源 的 操作 放 到 mutiThreadAccess 方法 中 ， 就 能 够 保证 这 个 方法 

在 同一 时 刻 只 能 被 一 个 线程 来 访问 ， 从 而 保证 了 多 线程 访问 的 安全 性 。 然 而 ， 当 一 个 方法 的 

方法 体 规模 非常 大 时 ， 把 该 方法 声明 为 synchronized 会 大 大 影响 程序 的 执行 效率 。 为 了 提高 

显 序 的 执行 效率 ，Java 语言 提供 了 synchronized 块 。 

2) synchronized 块 : 可 以 把 任意 的 代码 段 声明 为 synchronized， 也 可 以 指定 上 锁 的 对 象 ， 

有 非常 高 的 灵活 性 。 用 法 如 下 : 

Synchronized (syncObject) { 
// 访 问 syncObject 的 代码 


Ht 


} 


(2) wait 与 notify 

当 使 用 synchronized 来 修饰 某 个 共享 资源 的 时 候 , 如 果 线 程 Al 在 执行 synchronized 代码 ， 
另外 一 个 线程 A2 也 要 同时 执行 同一 对 象 的 同一 synchronized 代码 时 ， 线 程 A2 将 要 等 到 线程 
Al 执行 完成 后 ， 才 能 继续 执行 。 在 这 种 情况 下 ， 可 以 使 用 wait 方法 和 notify 方法 。 

在 synchronized 代码 被 执行 期 间 ， 线 程 可 以 调用 对 象 的 wait 方法 ， 释 放 对 象 锁 ， 进 入 等 
待 状态 , 并 且 可 以 调用 notify 方法 或 notifyAll 方法 通知 正在 等 待 的 其 他 线程 ,notify 方法 仅 唤 
醒 一 个 线程 〈 等 待 队列 中 的 第 一 个 线程 )， 并 允许 它 去 获得 锁 ， 而 notifyAll 方法 唤醒 所 有 等 待 
这 个 对 象 的 线程 ， 并 人 允许 它们 去 获得 锁 〈 并 不 是 让 所 有 唤醒 线程 都 获取 到 锁 ， 而 是 让 它们 去 
竞争 )。 

(3) Lock 

JDK5 新 增加 了 Lock 接口 以 及 它 的 一 个 实现 类 ReentrantLock〈 重 入 锁 )，Lock 也 可 以 用 
来 实现 多 线程 的 同步 ， 具 体 而 言 ， 它 提供 了 如 下 的 一 些 方法 来 实现 多 线程 的 同步 : 

1) lockO。 以 阻塞 的 方式 来 获取 锁 ， 也 就 是 说 ， 如 果 获 取 到 了 锁 ， 则 立即 返回 ， 如 果 其 
他 线程 持 有 锁 ， 当 前 线程 等 待 ， 直 到 获取 锁 后 返回 。 

2) tryLock0O。 以 非 阻塞 的 方式 获取 锁 。 只 是 答 试 忻 地 去 获取 一 下 锁 ， 如 有 果 获 取 到 锁 ， 则 
立即 返回 true， 否 则 ， 立 即 返回 false。 

3) tryLock(long timeout TimeUnit unit)。 如 果 获 取 了 锁 ， 立 即 返回 true; 和 否则， 会 等 待 参 
数 给 定 的 时 间 单 元 ， 在 等 待 的 过 程 中 ， 如 果 获 取 了 锁 ， 就 返回 true， 如 果 等 竺 超时 ， 则 返回 
false。 

4) lockImterruptibly0。 如 果 获 取 了 锁 ， 则 立即 返回 ， 如 果 没 有 获取 锁 ， 则 当前 线程 处 于 
休眠 状态 ， 直 到 获得 锁 ， 或 者 当前 线程 被 其 他 线程 中 断 〈 会 收 到 InterruptedException 异常 )。 
它 与 lock( 方 法 最 大 的 区 别 在 于 : 如果 lock() 方 法 获取 不 到 锁 ， 则 会 一 直 处 于 阻塞 状态 ， 且 会 
忽略 interrupt(0 方 法 。 如 下 例 所 示 : 


import java.util.concurrent.locks.Lock; 
import java.util.concurrent.locks.ReentrantLock; 
public class Test { 


public static void main(String[] args) throws InterruptedException{ 
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final Lock lock=new ReentrantLock(); 
lock.lock(); 
Thread tl=new Thread(new Runnable(){ 
public void run() { 
ty { 
lock.lockInterruptibly(); 
/lock.lock0; 编译 器 报错 
} catch (InterruptedException e) { 
System.out.printin(" interrupted."); 


} 
} 
)); 
tl].start(); 
tl.interrupt(); 
Thread.sleep(1); 
} 
3 
程序 运行 结果 如 下 : 
interrupted. 


如 果 把 lock.lockInterruptibly() 蔡 换 为 lock.lock()， 编 译 器 将 会 提示 lock.lockOcatch 代码 块 
无 效 ， 因 为 lock.lock0 不 会 抛 出 异常 ， 由 此 可 见 ，lock(0) 方 法 会 忽略 interruptO 引 发 的 异常 。 

6. 答案 ， HTML 的 Form 《表单 ) 是 一 个 包含 表单 元 素 的 区 域 。 表 单元 素 是 允许 用 户 在 
表单 中 (比如 文本 域 、 下 拉 列 表 、 单 选 框 和 复 选 框 等 ) 输入 信息 的 元 素 。 表 单 使 用 表单 标签 
(<form>) 定义 ， 例 如 <form><input/></form>。 
而 XForm 是 下 一 代 HTML 表单 标准 ， 它 比 HTML 提供 更 加 灵活 和 丰富 的 表单 控件 ， 同 
时 ， 它 要 比 HTML 更 加 规范 、 有 更 高 的 可 用 性 。 它 使 用 XML 来 定义 数据 ， 同 时 也 使 用 XML 
来 存储 及 传递 数据 。 它 最 特殊 的 一 点 是 分 隅 表单 的 数据 模型 、 视 图 和 控制 器 ， 数 据 与 表单 表 
示 的 分 离 ， 使 得 代码 更 加 清晰 ， 维 护 更 加 容易 。 数 据 模型 可 以 使 用 静态 的 XML 数据 ， 也 可 以 
是 后 端的 Web Service 或 URL 提供 。 

7. 答案 : 在 设计 Web 应 用 程序 的 时 候 ， 经 常 需要 将 一 个 系统 进行 结构 化 设计 ， 即 按照 
模块 进行 划分 ， 证 不 同 的 Servlet 来 实现 不 同 的 功能 , 例如 可 以 让 其 中 一 个 Servlet 接收 用 户 的 
请 求 ， 男 外 一 个 Servlet 来 处 理 用 户 的 请 求 。 为 了 实现 这 种 程序 的 模块 化 ， 就 需要 保证 在 不 同 
的 Servlet 之 间 可 以 相互 跳 转 , 而 Servlet 中 主要 有 两 种 实现 跳 转 的 方式 :forward 方式 与 redirect 

forward 是 服务 器 内 部 的 重 定向 ， 服 务 器 直接 访问 目标 地 址 的 URL， 把 那个 URL 的 响应 
内 容 读 取 过 来 ， 而 客户 端 并 不 知道 ， 因 此 ， 在 客户 端 浏览 器 的 地 址 栏 中 不 会 显示 转向 后 的 地 
址 ， 还 是 原来 的 地 址 。 由 于 在 整个 定向 的 过 程 中 用 的 是 同一 个 Request， 因 此 ，forward 会 将 
Request 的 信息 带 到 被 定向 的 JSP 或 Servlet 中 使 用 。 

redirect 则 是 客户 端 重 定向 ， 是 完全 的 跳 转 ， 即 客户 端 浏览 器 会 获取 到 跳 转 后 的 地 址 ， 然 
后 重新 发 送 请 求 ， 因 此 ， 浏 览 器 中 会 显示 跳 转 后 的 地 址 。 同 时 由 于 这 种 方式 比 forward 方式 多 
了 一 次 网 络 请 求 ， 所 以 ，forward 效率 更 高 。 需 要 注意 的 是 ， 客 户 端 重 定 向 可 以 通过 设置 特定 


191 


Java 程序 员 面 试 笔试 真题 库 


的 HITP 头 或 者 写 JavaScript 脚本 实现 。 图 17 可 以 更 好 地 说 明 它们 的 区 别 。 


Server Server 


Client 一 2 SendRedirect 
3. new Request 


Bk EO 
图 17 forward 方式 与 redirect 方式 


鉴于 以 上 区 别 ， 一般 当 forward 方式 可 以 满足 需求 时 ， 尽 可 能 地 使 用 forward 方式 。 但 在 
有 些 情况 下 ， 例 如 ， 需 要 跳 转 到 一 个 其 他 服务 器 上 的 资源 ， 则 必须 使 用 redirect 方式 。 

引申 : fter 的 作用 是 什么 ? 主要 实现 什么 方法 ? 

filter 使 用 户 可 以 改变 一 个 Request 并 且 修改 一 个 Response。filter 不 是 一 个 Servlet， 它 不 
能 产生 一 个 Response， 它 能 够 在 一 个 Request 到 达 Servlet 之 前 预 处 理 Request， 也 可 以 在 离开 
Servlet 时 处 理 Response。filter 其 实 是 一 个 “Servlet Chaining”(servlet 链 )。 

一 个 filter 包括 : 

1) 在 Servlet 被 调用 之 前 截获 。 

2) 在 Servlet 被 调用 之 前 检查 Servlet Request。 

3) 根据 需要 修改 Request 头 和 有 Request 数据 。 

4) 根据 需要 修改 Response 头 和 及 esponse 数据 。 

5) 在 Servlet 被 调用 之 后 截获 。 

8. 答案 : Overload 〈 重 载 ) 和 Override 〈 有 覆盖) 是 Java 多 态 性 的 不 同 表现 。 其 中 ， 重 载 
是 在 一 个 类 中 多 态 性 的 一 种 表现 ， 是 指 在 一 个 类 中 定义 了 多 个 同名 的 方法 ， 它 们 或 有 不 同 的 
参数 个 数 或 有 不 同 的 参数 类 型 。 在 使 用 重 载 时 ， 需 要 注意 以 下 几 点 ; 

1) 重 载 是 通过 不 同 的 方法 参数 来 区 分 的 ， 例 如 不 同 的 参数 个 数 、 不 同 的 参数 类 型 或 不 同 
的 参数 顺序 。 

2) 不 能 通过 方法 的 访问 权限 、 返 回 值 类 型 和 抛 出 的 异常 类 型 来 进行 重 载 。 

3) 对 于 继承 来 说 ， 如 果 基 类 方法 的 访问 权限 为 private， 那 么 就 不 能 在 派生 类 中 对 其 进行 
重 载 ， 如 果 派 生 类 也 定义 了 一 个 同名 的 函数 ， 这 只 是 一 个 新 的 方法 ， 不 会 达到 重 载 的 效果 。 

Override 是 指派 生 类 函数 覆盖 基 类 也 数 ， 宪 盖 一 个 方法 并 对 其 重 写 ， 以 达到 不 同 的 作用 。 
在 使 用 覆盖 时 ， 需 要 注意 以 下 几 点 : 

1) 派生 类 中 的 覆盖 方法 必须 和 基 类 中 被 覆盖 的 方法 有 相同 的 函数 名 和 参数 。 

2) 派生 类 中 的 覆盖 方法 的 返回 值 必须 和 基 类 中 被 覆盖 的 方法 的 返回 值 相同 。 

3) 派生 类 中 的 覆盖 方法 所 抛 出 的 异常 必须 和 基 类 中 被 覆盖 的 方法 所 抛 出 的 异常 一 致 或 
是 其 子 类 。 

4) 基 类 中 被 覆盖 的 方法 不 能 为 private， 和 否则 ， 其 子 类 只 是 定义 了 一 个 方法 ， 并 没有 对 其 


Client 


2. forward 


[ill 


敌 六 。 
重 载 与 履 盖 的 区 别 主要 有 以 下 儿 个 方面 : 
1) 履 盖 是 子 类 和 父 类 之 间 的 关系 ， 是 垂直 关系 ; 重 载 是 同一 个 类 中 方法 之 间 的 关系 ， 是 
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水 平 关系 。 

2) 履 盖 上 只 能 由 一 个 方法 或 只 能 由 一 对 方法 产生 关系 ;方法 的 重 载 是 多 个 方法 之 间 的 关系 。 

3) 履 新 要 求 参 数列 表 相同 ， 重 载 要 求 参数 列表 不 同 。 

4) 履 盖 关系 中 ， 调 用 方法 体 是 根据 对 象 的 类 型 〈 对 象 对 应 存储 空间 类 型 ) 来 决定 ; 而 重 
载 关 系 是 根据 调用 时 的 实 参 表 与 形 参 表 来 选择 方法 体 的 。 

如 果 在 一 个 类 中 定义 了 多 个 同名 的 方法 , 它们 或 有 不 同 的 参数 个 数 或 有 不 同 的 参数 类 型 ， 
则 称 为 方法 的 重 载 。Overload 的 方法 是 可 以 改变 返回 值 的 类 型 ， 但 是 Override 方法 不 能 改变 
返回 值 类 型 。 

9. 答案 : 是 合法 的 。 

虽然 文件 名 被 命名 为 B.java 是 合法 的 ， 但 是 这 段 代 码 在 Eclipse 下 是 无 法 运行 的 。 因 为 
Eclipse 在 运行 的 时 候 会 首先 编译 B.java 文件 ,然后 会 在 B.class 文件 中 找 Java 的 入 口 方法 (main 
方法 )， 显 然 是 找 不 到 的 ， 因 为 通过 javac B.java 命令 编译 后 只 会 生产 一 个 A.class 文件 (Java 
在 编译 时 ， 会 对 每 个 类 生成 一 个 .class 文件 ，.class 的 文件 名 与 类 名 相同 )。 在 命令 行 下 ， 可 以 
通过 java A 命令 来 运行 这 个 程序 。 

10. 答案 : HTML 只 能 用 来 保存 静态 内 容 ， 而 通常 情况 下 ， 静 态 页 面 很 难 满足 实际 应 
用 的 需要 ， 鉴 于 此 ， 提 出 了 动态 页 面 的 概念 。 所 谓 动 态 页 面 ， 指 的 是 能 够 根据 不 同时 间 、 
不 同 用 户 而 显示 不 同 内 容 的 页 面 ， 例 如 常见 的 论坛 、 留 言 板 以 及 电子 商务 网 站 等 都 是 通过 
动态 页 面 来 实现 的 。 那 么 如 何 才 能 生成 动态 页 面 呢 ? 其 中 一 种 方法 是 采用 CGI (Common 
Gateway Interface， 公 共 网 关 接 口 )。CGI 是 一 种 用 Perl 脚本 、Shell 脚本 或 C 语言 编写 的 
程序 ， 它 可 以 用 来 生成 动态 页 面 ， 即 每 次 客户 端 浏 览 器 访问 某 一 页 面 时 ， 可 以 看 到 不 同 的 
内 容 。CGI 应 用 开发 比较 困难 , 一 般 会 要 求 程 序 员 有 处 理 参数 传递 知识 的 能 力 , 而 且 , CGI 
不 可 移植 ， 为 某 一 特定 平台 编写 的 CGI 应 用 只 能 运行 于 这 一 环境 中 。 每 一 个 CGI 应 用 存 
在 于 一 个 由 客户 端 请 求 激活 的 进程 中 ， 并 且 在 请 求 被 服务 后 被 卸载 。 而 另外 一 种 方式 则 是 
采用 Servlet 技术 。 

什么 是 Servlet 呢 ? Servlet 是 采用 Java 语言 编写 的 服务 器 端 程 序 ， 它 运行 于 Web 服务 器 

的 Servlet 容器 中 ， 它 的 主要 功能 是 提供 请 求 /响应 的 Web 服务 模式 ， 可 以 生成 动态 的 Web 
内 容 ， 而 这 正 是 HTML 所 不 具备 的 功能 。 

与 其 他 生成 动态 页 面 的 技术 相 比 ，Servlet 有 诸多 优点 ， 具 体 而 言 ， 主 要 表现 在 如 下 几 个 
方面 : 

1) 较 好 的 可 移植 性 。 由 于 Java 语言 具有 跨 平 台 和 可 移植 性 强 的 特点 ， 使 得 Servlet 也 有 
较 好 的 可 移植 性 ， 即 无 须 修改 代码 就 可 以 部 署 到 多 种 不 同类 型 的 Web 服务 器 上 。 

2) 执行 效率 高 。 由 于 CGI 针对 每 个 请 求 都 会 创建 一 个 进程 来 处 理 ， 而 Servlet 针对 每 个 
请 求 创建 一 个 线程 来 执行 ， 而 创建 线程 比 创建 进程 的 开销 要 小 ， 所 以 ， 与 CGI 相 比 ，Servlet 
在 交互 过 程 中 有 更 短 的 响应 时 间 ， 响 应 效率 更 高 。 

3) 功能 强大 。Servlet 可 以 与 Web 服务 器 进行 交互 ， 而 CGI 却 无 法 与 Web 服务 器 直接 
交互 。 

4) 使 用 方便 。Servlet 提供 了 许多 非常 有 用 的 接口 用 来 读 取 或 设置 HTTP 头 消息 ， 处 理 
Cookie 和 跟踪 会 话 状态 等 。 


5) 可 扩展 性 强 。 由 于 Servlet 是 由 Java 语言 编写 的 ， 所 以 ， 它 具备 了 Java 语言 的 所 有 优 
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点 。Java 语言 是 健壮 的 、 面 向 对 象 的 编程 语言 ， 很 容易 扩展 ，Servlet 自然 也 具备 这 样 的 优点 。 

四 、 编 程 题 

1. 答案 : 本 题 考察 的 是 对 排序 算法 的 理解 ， 以 选择 排序 为 例 分 析 如 下 : 

选择 排序 是 一 种 简单 直观 的 排序 算法 ， 其 基本 原理 如 下 : 对 于 给 定 的 一 组 记录 ， 经 过 第 
一 轮 比 较 后 得 到 最 小 的 记录 ， 然 后 将 该 记录 与 第 一 个 记录 的 位 置 进行 交换 ， 接 着 对 不 包括 第 
一 个 记录 以 外 的 其 他 记录 进行 第 二 轮 比 较 ， 得 到 最 小 的 记录 并 与 第 二 个 记录 进行 位 置 交换 ; 
重复 该 过 程 ， 直 到 进行 比较 的 记录 只 有 一 个 时 为 止 。 实 现代 码 如 下 : 

public class TestSort 


{ 


public static void selectSort(int[] a) 
{ 
int i; 
int j; 
int temp = 0; 
int flag = 0; 
int n=a.length; 
for 1=0;i<n;1++) 
{ 
temp = al[j]; 
flag=i; 
ford =i+1l;j<n;j++) 
{ 
if (alj] < temp) 
{ 
temp = alj]j; 
flag =j; 
} 
} 
if (flag !=1) 
{ 
a[flag] = ali]; 
a[li] = temp; 


} 
} 
public static void main(String[] args) 
{ 
inti= 0; 
int a[] = {1,8,5,2,4,9,7}; 
selectSort(a); 
for(i= 0;1<a.length; i++) 
System.out.print(a[i]+" "); 
System.out.println("\n"); 


-~ 
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2. 答案 : 示例 代码 如 下 ; 


import java.sql.*; 
public class Test 


public Connection getConnection() 


{ 


Connection conn = null; 


二 


String driver = "oracle.jdbc.driver.OracleDriver"; 


String url 


= Wis 
和 


一 


String name = "user"; 
String psw = "password"; 
try 
{ 
Class.forName(driver); 
conn = DriverManager.getConnection(url, name, psw); 
}catch (ClassNotFoundException e) { 
e.printStackTrace(); 
} catch (SQLException e) { 
e.printStackTrace(); 


} 


return conn; 


public void selectFromOracle() 

{ 
Connection conn = null; 
PreparedStatement pstat = null; 
ResultSet rs = null; 
try 
{ 


conn = getConnection(); 


pe 


String sql = "select name,score from Student where name=?",; 
pstat = conn.prepareStatement(sq]l); 

pstat.setString(1, "James"); 

rs= pstat.executeQuery(); 

while (rs.next()) 


{ 


System.out.println(rs.getString("name")+","+rs.getInt("score"));; 


} 


} catch (SQLException e) { 
e.printStackTrace(); 
}finally 


{ 
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序 员 


iflrs 


if(ps 


!=nul]) 

try { 
rs.close(); 

} catch (SQLException e) { 
e.printStackTrace(); 


} 


tat!=null) 
ty { 
pstat.close(); 
} catch (SQLException e) { 
e.printStackTrace(); 


} 


if(conn!=null) 


try { 
conn.close(); 
} catch (SQLException e) { 


e.printStackTrace(); 
} 
} 

3. 答案 : 在 某 些 情况 下 ， 有 些 对 象 上 只 需要 一 个 就 可 以 了 ， 即 每 个 类 只 需要 一 个 实例 ， 例 
如 ， 一 台 计 算 机 上 可 以 连接 多 台 打 印 机 ， 但 是 这 个 计算 机 上 的 打印 程序 只 能 有 一 个 ， 这 里 就 
可 以 通过 单 例 模式 来 避免 两 个 打印 作业 同时 输出 到 打印 机 中 ， 即 在 整个 的 打印 过 程 中 只 有 一 
个 打印 程序 的 实例 。 此 时 ， 就 需要 使 用 到 单 例 模式 。 简 单 来 说 ， 单 例 模式 (也 叫 单 件 模式 》 
的 作用 就 是 保证 在 整个 应 用 程序 的 生命 周期 中 ， 任 何 一 个 时 刻 ， 单 例 类 的 实例 都 只 存在 一 个 
(当然 也 可 以 不 存在 )。 


单 例 模 式 能 够 确保 某 一 个 类 只 有 一 个 实例 ， 而 且 自 行 实例 化 3 


向 整个 系统 提供 这 个 实例 


如 图 18 所 示 。 


单 例 模 式 。 单 例 模 式 只 应 在 有 真正 的 “ 单 


实例 ”的 需求 时 才 可 使 用 。 单 例 模式 的 设计 类 图 


-static uniqueInstance 
-otherAttribute 
+static getInstanceOO 
+otherMethods() 
图 18 单 例 模式 设计 类 图 
其 中 ， 类 变量 uniqueInstance 持 有 唯一 的 单 例 实例 ， 类 方法 getmstanceO 用 来 获取 唯一 的 
实例 化 对 象 。 
需要 区 分 一 下 全 局 变量 和 单 例 模式 首先， 全 局 变量 是 对 一 个 对 象 的 静态 引用 ， 它 确实 
可 以 提供 单 例 模式 实现 的 全 局 访问 这 个 功能 ， 但 是 并 不 能 保证 应 用 程序 中 只 有 一 个 实例 ， 同 


人 


Pp， 也 明确 


la} 
是 全 


已 
日 


局 变量 并 


时 ， 在 编码 规范 9 
码 难 读 ， 还 有 就 
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是 还 是 可 以 实现 继承 的 )。 而 对 于 单 例 模 式 而 言 ， 其 在 类 中 保存 了 它 的 唯一 实例 ， 这 个 类 可 以 
保证 只 能 创建 一 个 实例 ， 同 时 还 提供 了 一 个 访问 该 唯一 实例 的 全 局 访问 点 。 

需要 注意 的 是 ， 单 例 模 式 是 用 来 实现 在 整个 程序 中 上 只 有 一 个 实例 。 单 例 类 的 构造 方法 必 
须 为 私有 ， 同 时 ， 单 例 类 必须 提供 一 个 全 局 访问 点 。 示 例 代 人 码 如 下 : 


public class Test 
{ 
private Test() {} 
private static Test uniqueInstance= new Test(); 
public static Test getInstance() 
{ 
return uniqueInstance; 


} 


} 


使 用 这 种 方法 实现 的 单 例 模式 ， 在 类 被 加 载 时 就 会 实例 化 这 个 类 的 一 个 对 象 ， 由 于 在 使 
用 之 前 对 象 已 经 创建 好 ， 因 此 ， 可 以 在 多 线程 环境 下 使 用 这 种 方法 。 如 果 采 用 按 需 实例 化 的 


方法 〈 在 实例 化 对 象 被 使 用 的 时 候 才 实例 化 )， 就 需要 考虑 多 线程 的 同步 。 
4. 答案 : 示例 代码 如 下 : 


public class Test 


{ 
public static void main(String[] args) 
{ 
int sum = 0; 
for(int i=1;i<100;i+=2) 
{ 


sum = SUm 十 1; 


} 


System.out.println("1+3+5+...+99 = "+sum); 


= 一 


7 到 某 初 创 公 司 软件 工程 师 笔 试题 


一 、 选 择 题 (可 多 选 ) 

1. 答案 : C。 

分 析 : 本 题 考察 的 是 对 Java 运行 环境 的 理解 。 
平台 独立 性 指 的 是 可 以 在 一 个 平台 上 编写 和 编译 程序 ， 而 在 其 他 平台 上 运行 。 保 证 Java 
语言 具有 平台 独立 性 的 机 制 为 “中 间 码 ”和 “JVM (Java Virtual Machine，Java 虚拟 机 )” Java 
程序 被 编译 后 不 是 生成 能 在 硬件 平台 上 可 执行 的 代码 ， 而 是 生成 了 一 个 中 间 代 码 。 不 同 的 硬 
件 平 台 上 会 安装 有 不 同 的 JVM, 由 JVM 负责 将 中 间 代 码 翻译 成 硬件 平台 能 执行 的 代码 。 由 此 
可 以 看 出 ，JVM 不 具有 平台 独立 性 ， 与 硬件 平台 是 相关 的 ， 它 保证 了 Java 可 以 实现 跨 平 台 。 
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本 题 中 ,对 于 选项 A，JRE 是 运行 Java 程序 所 必需 的 环境 的 集合 ,包含 JVM 标准 实现 以 


及 Java 核心 类 库 。 所 以 ， 选 项 A 不 正确 。 
对 于 选项 B，JDK 是 Java 语言 开发 的 工具 包 ， 主 要 用 于 移动 设备 、 髓 入 式 设备 上 的 Java 


点 用 程序 ， 包 括 javac、jar 、javadoc、jdb、java、appletviewer、javah 和 Javap 等 基本 组 件 。 


所 以 ， 选 项 B 不 正确 。 


对 于 选项 C，JVM 是 一 个 虚构 
算 机 功能 来 实现 的 。 它 是 Java 语言 跨 平 台 的 核心 。 所 


来 的 计算 机 ， 是 通过 在 实际 的 计算 机 上 仿真 模拟 各 种 计 


以 ， 选 项 C 正确 。 


对 于 选项 D，OS 全 称 为 Operating System， 指 的 是 操作 系统 ， 与 Java 路 平台 没有 关系 。 


所 以 ， 选 项 D 不 正确 。 


所 以 ， 本 题 的 答案 为 C。 


2. 答案 : B。 
分 析 : 本 题 考察 的 是 操 


在 编程 的 时 候 ， 经 常会 


和 - 符 知识 。 


例 ， 有 两 种 自 增 方式 : 前 置 : 


是 在 程序 执行 完毕 后 自 增 ， 而 前 置 ++i 是 在 程序 开 


用 到 变量 的 自 增 或 自 减 操作 ， 尤 其 在 循环 中 用 得 最 多 。 以 自 增 为 
了 后 置 ， 以 变量 i 为 例 ， 即 


+H 和 it+， 它 们 的 不 同 点 在 于 后 置 计 + 


正确 。 


然后 再 执行 n 的 递增 操作 ， 因 


所 以 ， 本 题 的 答案 为 B。 


3. 答案 : A、C、D 


分 析 : 本 题 考 察 的 是 Java 关键 字 知 识 。 


对 于 选项 A，public 是 作用 域 修 


所 有 类 或 对 象 都 可 以 直接 访问 。 所 以 ， 选 项 A 正确 。 
言 中 ， 变 量 名 是 区 分 大 小 写 的 。 例 如 ，Count 与 count 被 认为 是 两 
个 不 同 的 标识 符 ， 而 非 相 同 的 标识 符 。Static 不 是 Java 的 关键 字 ， 而 static 是 Java 的 关键 字 ， 


对 于 选项 B， 在 Java 语 


于 始 执行 前 进行 目 增 。 

对 于 本 题 而 言 ， 整 型 变量 n 初始 化 为 999， 执 行 完 n-- 后 ,，n 的 值 变 为 998， 接 着 执行 +tn 
后 n 的 值 变 为 999， 最 关键 的 一 步 输出 nt+， 这 个 输出 语句 的 执行 过 程 为 首先 输出 n 的 值 ， 
此 ， 程 序 输 出 为 99， 输 出 后 n 的 值 变 为 1000。 所 以 ， 选 项 也 


饰 符 ， 表 明 属 性 变量 或 方法 对 所 有 类 或 对 象 都 是 可 见 的 ， 


对 于 选项 C，Java 程序 的 入 


C 正确 。 


[本 


4. 答案 : B。 


对 于 选项 D， 直 为 流程 控制 的 关键 字 
所 以 ， 本 题 的 答案 为 A、 


C、D 


分 析 : 本 题 考 察 的 是 Java 语言 知识 。 


在 Java 语言 中 ，byte 只 占 了 1B (8bit)， 


它 的 取 值 范围 为 [-128，127]， 因 此 ， 只 有 选项 


用 来 修饰 方法 或 属性 ， 表 明 方法 或 属性 是 属于 类 的 方法 或 属性 。 所 以 ， 选 项 B 不 正确 。 
方法 为 main， 因 此 ，main 也 是 Java 的 关键 字 。 所 以 ， 选 项 


。 所 以 ， 选 项 D 正确 。 


是 合法 的 ，byte 的 包装 类 为 Byte， 也 可 以 通过 下 面 


的 代码 来 查看 byte 的 最 大 值 和 最 小 值 : 


System.out.printIn(Byte.MAX VALUE); 
System.out.println(Byte.MIN_ VALUE); 


所 以 ， 本 题 的 答案 为 B。 
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5. 答案 : B。 


分 析 : 本 题 考 察 的 是 Java 语言 知识 。 


在 Java 语言 中 ，byte 只 占 了 一 个 字 节 ， 它 的 取 值 范围 为 [-128，127]。 当 数字 为 127 时 ， 


是 byte 的 最 大 值 ， 没 有 游 出。 如 果 将 128 强制 转换 为 byte， 此 时 会 溢出 ， 相 当 于 最 小 的 负数 


-128。 所 以 ，129 


被 强制 转换 为 byte 后 的 值 就 是 -127。 所 以 ， 选 项 B 正确 。 


所 以 ， 本 题 的 答案 为 B。 


6. 答案 : G、H。 


参见 真题 $ 


简 答题 3。 


7. 答案 : D。 

分 析 : 本 题 考察 的 是 对 do/while 和 for 循环 执行 过 程 的 理解 。 

do/while 循环 是 while 循环 的 变 体 。 在 检查 条 件 是 否 为 真 之 前 ， 该 循环 首先 会 执行 一 次 代 
码 块 ， 然 后 检查 条 件 是 否 为 真 ， 如 果 条 件 为 真 ， 就 会 重复 这 个 循环 。 


for 循环 语句 


的 基本 结构 如 下 : 


for (表达 式 1; 表 达 式 2; 表 达 式 3) 


{ 
循环 
} 


体 


它 的 执行 过 程 如 下 : 
1) 执行 初始 化 语句 : 表达 式 1〈 只 会 被 执行 一 次 )。 


2) 执行 表达 式 2， 如 果 表 达 式 2 的 结果 为 false， 则 结束 循环 ， 和 否则， 执行 循环 体 ， 然 后 


执行 表达 式 3。 
3) 循环 步骤 


2)， 直 到 表达 式 2 的 结果 为 false 时 退出 循环 ， 或 者 循环 体内 有 退出 循环 的 


语句 (return 或 break)。 

对 于 本 题 而 言 ， 第 一 次 进入 for 循环 体 时 ，i=4; 然后 进入 do/while 循环 体 ， 此 时 j=0， 然 
后 这 个 循环 一 直 执行 jt+， 直 到 j=2 或 j>i 的 时 候 退 出 循环 体 ， 显 然 会 先 满足 j=2 的 条 件 退出 
循环 体 ， 此 时 j 的 值 为 2， 因 此 ， 输 出 2。 下 一 次 for 循环 的 时 候 ，f3， 同 理 输出 结果 仍然 为 
2。 下 一 次 for 循环 的 时 候 ，f2， 同 理 输出 结果 为 2。 下 一 次 for 循环 的 时 候 ，i=1， 同 理 也 会 
输出 2， 此 时 执行 for 循环 的 -操作 , i 的 值 变 为 0, 不 满足 i>0 的 条 件 ， 因 此 ，for 循环 结束 ， 


所 以 ， 输 出 结果 为 2222。 所 以 ， 选 项 DD 正确 。 


所 以 ， 本 题 的 答案 为 D。 


8. 答案 : Cs 


D、 E, 


分 析 : 本 题 考察 的 是 数组 知识 。 


在 Java 语言 ! 


， 二 维 数组 有 如 下 三 种 声明 的 方法 : 


1) type arrayName[][]; 
2) type[][] arrayName; 
3) type[] arrayNamel[]; 


需要 注意 的 是 ， 在 声明 二 维 数 组 时 ， 其 中 方 插 号 [] 中 内 容 必须 为 空 。 


1 此 可 见 ， 只 有 选项 C、 选 项 DD 及 选项 EE 是 正确 的 。 
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所 以 ， 本 题 的 答案 为 C、D、E。 
9. 答案 : A、C。 


分 析 : 本 题 考察 的 是 对 Java 代码 结构 的 


package 的 中 文 意思 是 包 ， 它 是 一 个 比较 ] 


里 解 。 


后 从 根 开 始 有 目录 和 文件 ， 目 录 中 扔 套 目 录 。 
具体 而 言 ，package 主要 有 以 下 两 个 作用 : 


过 使 用 package， 使 得 处 于 不 同 package 中 的 类 可 以 存在 相 
分 类 ， 使 项 目的 组 织 更 加 清晰 。 当 开发 一 个 有 非常 多 的 类 的 项 目 
类 进行 分 类 ， 而 是 把 所 有 的 类 都 放 在 一 个 package 下 ， 这 样 的 代码 不 仅 可 读 性 差 ， 而 


护 性 也 不 好 ， 会 严重 影响 开发 效率 。 


和 象 的 逻辑 概念 ， 它 的 宗旨 是 将 .java 文件 (Java 
源 文 件 )、.class 文件 (编译 后 的 文件 ) 以 及 其 他 resource 文件 (例如 .xml 文件 、 
文件 和 .txt 文件 等 ) 有 条 理 地 进行 组 织 ， 以 供 使 用 。 


.avi 文件 、.mp3 


这 类 似 于 Linux 文件 系统 ， 有 一 个 根 ， 然 


第 一 ， 提 供 多 层 命 令 空 


间 ， 解 决 命名 ? 


package 的 用 法 一 般 如 下 〔 源 文件 所 在 目录 为 当前 目录 ): 


在 每 个 源 文件 的 开头 加 上 “package packagename;”， 然后 在 源 文件 所 在 目录 下 创建 一 新 


目录 ， 名 称 为 packagename。 package 必须 出 现在 该 类 的 第 一 行 〈 不 含 注 释 )。 所 以 ， 选 项 D 


正太 


和 ， 选 项 C 错误 。 
| 于 一 个 类 只 能 属于 
以 ， 选 项 A 错误 。 


import 用 来 导入 需要 使 用 的 类 。 根据 实际 情况 ， 代 码 中 可 以 导入 多 个 类 来 使 用 ， 


import 可 以 出 现 多 次 。 所 以 ， 选 项 B 正确 。 
所 以 ， 本 题 的 答案 为 A、C。 
10. 答案 ， A、C。 
分 析 : 本 题 考察 的 是 对 可 变 参 数 的 理解 。 


在 Java 语言 ! 


， 可 以 使 用 省 略 号 ... 来 实现 可 变 参数 ， 可 变 参 数 通 
1) 只 能 作为 最 后 一 个 参数 出 现 。 如 果 参 数 个 数 不 定 , 当 其 后 


语言 无 法 区 分 传 入 的 参数 属于 前 一 个 可 变 参 数 还 是 后 面 的 参数 ， 所 以 ， 只 能 让 可 变 参 数位 于 


最 后 一 项 。 
2) 只 能 位 于 变量 的 类 型 和 变量 名 之 间 。 


3) 编译 器 为 可 变 参数 隐 含 创建 一 个 数组 ， 在 调 


参数 ， 如 下 例 所 示 : 


个 package， 因 此 ， 在 一 个 类 中 ，package 最 多 只 能 出 现 一 次 。 


常 有 如 下 几 个 特点 : 


因此 ， 


司 的 名 字 ; 第 二 ， 对 类 按 功 能 进行 
时 ， 如 果 不 使 用 package 对 
且 可 维 


所 


边 还 有 相同 类 型 参数 时 , Java 


L 


] 的 时 候 ， 可 以 用 数组 的 形式 来 访问 可 变 


public class Test 


{ 


public static void main(String[] args) 
{ 
print(1,2); 
} 
public static void print(int... args) 
{ 
for (inti= 0; i< args.length; i++) 


{ 
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System.out.println(args[i]); 


} 
} 
} 
程序 的 运行 结果 为 


对 于 本 题 而 言 ， 选 项 A 和 选项 C 满足 变 参 的 要 求 。 所 以 ， 选 项 A 与 选项 C 正确 。 

对 于 选项 B， 有 两 个 名 字 相 同 的 参数 。 所 以 ， 选 项 B 错误 。 

对 于 选项 D， 变 参 不 是 作为 最 后 一 个 参数 出 现 的 。 所 以 ， 选 项 D 错误 。 

所 以 ， 本 题 的 答案 为 A、C。 

11. 答案 ， A。 

分 析 : 本 题 考察 的 是 对 接口 和 抽象 类 的 理解 。 

如 果 一 个 类 中 包含 抽象 方法 ， 那 么 这 个 类 就 是 抽象 类 。 在 Java 语言 中 ， 可 以 通过 将 类 或 
者 类 中 的 某 些 方法 声明 为 abstract 来 表示 一 个 类 是 抽象 类 。 接口 就 是 指 一 个 方法 的 集合 ， 接 
中 的 所 有 方法 都 没有 方法 体 ， 在 Java 语言 中 ， 接 口 是 通 过 关键 字 interface 来 实现 的 。 

在 实际 使 用 的 时 候 ， 接 口 可 以 继承 接口 ， 抽 象 类 可 以 实现 接 | 每 类 也 可 以 继承 具 
体 类 


通过 以 上 分 析 可 知 ， 选 项 A 是 正确 的 ， 因 为 接口 可 以 继承 接口 。 
对 于 选项 B， 接 口 不 能 继承 抽象 类 ， 因 为 接口 中 所 有 的 方法 不 能 有 方法 体 ， 而 抽象 类 ， 
的 方法 是 可 以 有 方法 体 的 。 因 此 ， 选 项 B 错误 。 
对 于 选项 C，implements 关键 字 是 指 子 类 要 实现 接口 中 定义 的 方法 ， 因 为 接口 中 的 方法 
是 没有 方法 体 的 ， 所 以 接口 不 能 用 来 实现 接口 。 因 此 ， 选 项 C 错误 。 
对 于 选项 D， implements 只 能 用 来 实现 接口 ， 而 Interface 是 个 抽象 类 ， 对 于 抽象 类 只 能 
用 extends 来 实现 。 因 此 ， 选 项 D 错误 。 

所 以 ， 本 题 的 答案 为 A。 

12. 答案 : C、D。 

分 析 : 本 题 考察 的 是 Map 知识 。 

对 于 选项 A，SortedMap 继承 了 Map， 使 按键 保持 升序 排列 ， 它 还 是 个 接口 ， 因 此 ， 也 
法 直接 实例 化 。 所 以 ， 选 项 A 错误 。 

对 于 选项 B，Map 是 一 个 接口 ， 因 此 ， 它 无 法 直接 实例 化 。 所 以 ， 选 项 B 错误 。 

对 于 选项 C 和 DD，HashMap 和 TreeMap 都 实现 了 接口 Map， 它 们 是 两 个 具体 的 实现 类 ， 
因此 ， 可 以 实例 化 。 所 以 ， 选 项 C 与 选项 D 正确 。 
所 以 ， 本 题 的 答案 为 C、D。 

13. 答案 : D。 
分 析 : 本 题 考 察 的 是 对 Collection 框架 的 理解 。 
Collection 的 框架 如 图 19 所 示 。 


a 
MH 
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图 19 ”Collection 框架 


| 此 可 见 ，HashMap 不 是 Collection 的 子 接口 ，List 和 Set 是 Collection 的 子 接口 ， 
SortedSet 继承 了 Set 接口 ， 因 此 ， 也 属于 Collection 的 子 接口 。 所 以 ， 选 项 DD 正确 。 


以 ， 本 题 的 答案 为 DD。 

答案 : A、C。 

分 析 : te Java 异常 处 理 知识 。 

Java 语言 中 ， 使 用 try/catch/finally 对 异常 进行 处 理 ，Java 编译 器 只 允许 如 下 三 种 组 合 


try/catch 。 


2) try/finally。 
3) try/catch/finally。 


其 中 ,try 块 只 能 有 一 个 ，finally 块 是 可 选 的 ， 最 多 只 能 有 一 个 finally 块 ，catch 块 可 以 有 


多 个 ， 执行 的 顺序 为 try->catch->finally。 当 然 ， 如 果 没 有 异常 发 生 ， 那 么 catch 块 是 不 会 执行 


的 ; 当 


匹配 的 ， 
块 在 任何 情况 下 都 会 执行 ， 无 论 有 没有 发 生 异 常 ， 它 总 会 在 这 个 异常 处 理 结构 的 最 后 运行 。 


有 多 个 catch 块 的 时 候 ， 如 果 try 块 中 出 现 异常 ， 异 常 是 按照 catch 块 的 先后 顺序 进行 
旦 异常 类 型 被 一 个 catch 块 匹 配 ， 则 不 会 与 后 面 的 catch 块 进行 匹配 ; 最 后 ,finally 


即使 在 try 块 内 用 return 返回 了 ， 在 返回 前 ，finally 也 总 是 要 执行 ， 以 便 能 够 在 异常 处 理 的 最 


后 做 一 些 清理 工作 ， 例 如 关闭 数据 库 连 接 等 。 
对 于 本 题 而 言 : 


对 于 选项 A， 通 过 try/catch 可 以 捕获 运行 期 间 出 现 的 错误 ， 进 行 处 理 后 可 以 使 程序 继续 


运行 ， 


内 此 ， 是 一 种 积极 的 异常 处 理 方式 。 所 以 ， 选 项 A 正确 。 


对 于 选项 B，try 后 面 可 以 不 跟 catch， 而 直接 跟 frallys 所 以 ， 选 项 B 错误 。 

对 于 选项 C， 由 于 catch 存在 的 作用 就 是 为 了 匹配 异常 类 型 ， 因 此 ，catch 必须 指定 
类 型 和 变量 名 称 。 所 以 ， 选 项 C 正确 。 

对 于 选项 D，finally 块 在 任何 情况 下 都 会 执行 。 所 以 ， 选 项 D 错误 。 

对 于 选项 E， 当 需要 捕获 多 种 不 同类 型 的 异常 的 时 候 ， 传 统 的 写法 为 
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catch (IOException el) { 
} 


catch (Exception e2) { 


} 


为 了 降低 代码 的 重复 度 ，JDK1.7 引入 了 新 的 写法 : 如 果 用 一 个 catch 块 处 理 多 个 异常 ， 
可 以 用 管道 符 (|) 将 它们 分 开 ， 即 catchLOException | Exception e) 们 ， 由 此 可 以 看 出 ,，“|” 前 
面 的 异常 是 不 能 单独 制定 变量 名 的 。 所 以 ， 选 项 玉 错误 。 

所 以 ， 本 题 的 答案 为 A、C。 

15. 答案 B、C、E。 

参见 真题 3 中 问答 题 $。 

16. 答案 : C。 

分 析 : 本 题 考察 的 是 对 随机 函数 的 理解 。 

对 于 选项 A，Math 类 的 random 方法 的 功能 是 生成 [0,1) 的 小 数 ， 不 能 生成 1。 因 此， 选项 
A 错误 。 

对 于 选项 B，Random 类 没有 next 这 个 方法 。 因 此 ， 选 项 B 错误 。 

对 于 选项 C，nextInt(n) 方 法 的 功能 是 生成 [0,n) 的 整数 ， 所 以 ，nextInt(11) 可 以 生成 [0,11)， 
即 [0,10] 的 整数 。 因 此 ， 选 项 C 正确 。 

对 于 选项 D，java.util 包 下 没有 Math 类 ，Math 类 属于 java.lang 包 。 因 此 ， 选 项 D 错误 。 

所 以 ， 本 题 的 答案 为 C。 

二 、 简 答题 

1. 答案 : 如 果 使 用 返回 值 对 方法 进行 重 载 ， 在 调用 的 时 候 会 产生 二 义 性 ， 调 用 者 无 法 确 
定 到 底 该 调用 哪个 方法 。 如 下 例 所 示 : 


rs 


class Test 
{ 
public float flint a, int b) 
{ 
return a+b; 
} 
public int f(int a, int b) 
{ 
return a+b+1l; 
} 
public static void main(String[] args) 
{ 
Test t=new Test(); 
t.add(1, 2); /调用 哪个 方法 ? ? 
} 
} 


在 调用 方法 tadd(1, 2) 的 时 候 ， 无 法 确定 到 底 该 调用 哪个 方法 。 因 此 ， 无 法 通过 返回 值 对 
方法 进行 重 载 。 
2. 答案 : 可 以 使 用 volatile 来 修饰 数组 。 在 这 种 情况 下 ，volatile 是 用 来 修饰 指向 数组 的 
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这 个 引用 ， 而 不 是 数组 的 内 容 


。 也 就 是 说 ， 如 果 一 个 线程 修改 了 这 个 数组 的 引用 ， 使 其 指向 


其 他 的 数组 ， 在 volatile 的 保 订 
了 数组 的 内 容 ， 
见 〈 其 他 的 线程 


可 能 会 从 缓存 


由 于 数组 的 内 容 没有 被 volatile 修饰 ， 


FE 下 ， 其 他 线程 可 以 马上 获取 到 这 个 变化 。 而 如 果 一 个 线程 修改 
因此 ， 这 个 修改 有 可 能 对 其 他 线程 不 可 


中 读 取 )。 


3. 答案 : 在 Java 中 ， 当 参与 运算 的 两 个 数 是 byte、short 或 int 时 ， 它 们 首先 都 会 被 转换 
为 int 类 型 ， 再 进行 计算 。 然 后 把 计算 的 结果 赋值 给 用 来 存储 结果 的 变量 。 如 果 用 来 存储 结果 
变量 的 类 型 是 byte 或 short， 这 意味 着 需要 把 int 类 型 转换 为 byte 或 short 类 型 。a+=b 会 隐 式 
地 把 运算 结果 转换 为 a 的 类 型 。 而 a=at+b 不 会 把 a+b 运算 结果 的 类 型 隐 式 转换 为 a 的 类 型 。 

如 下 例 所 示 : 

class Test 
{ 
public static void main(String[] args) 
{ 
Short a=1; 
short c=2; 
int b=2; 
at+=b;// 运 算 结果 隐 式 转换 为 short 
System.out.println("a="+a); 
//a=atc; // 编 译 错误 ， 因 为 atc 结果 为 int 类 型 ,不 能 隐 式 转 为 int 
a=(short)(atc); 
System.out.println("a="+a); 
} 
} 
程序 的 运行 结果 为 
a=3 
a=5 
4. 答案 : 在 Java 语言 中 ， 每 个 Java 应 用 程序 都 有 一 个 Runtime 类 实例 ，Runtime 类 提供 
了 多 个 查看 内 存 使 用 情况 的 方法 ， 如 下 例 所 示 : 
class Test 
public static void main(String[] args) 
{ 
/得 到 JVM 中 的 空闲 内 存量 (单位 是 字 他 ) 
System.out.println(Runtime.getRuntime(.freeMemory(O); 
/得 到 JVM 内 存 总 量 (单位 是 字 节 ) 
System.out.printIn(Runtime.getRuntime().total Memory()); 
WJVM 试图 使 用 的 最 大 内 存量 (单位 是 字 节 ) 
System.out.println(Runtime.getRuntime().max Memory()); 
/可 用 处 理 器 的 数 
System.out.println(Runtime.getRuntime().availableProcessors()); 
} 
} 


204 


程序 的 运行 结果 为 


250588512 
253231104 
3747086336 
4 


5. 答案 : 在 开发 Web 应 用 程序 的 时 候 ， 经 常 需要 能 够 做 到 数据 共享 或 者 在 不 同 页 面 之 
间 传 递 参 数 ， 而 且 ， 一 个 会 话 中 的 数据 可 能 会 在 不 同 的 地 方 使 用 ， 因 此 ， 就 需要 有 专用 的 机 
制 来 传递 和 保存 这 些 数 据 。 

所 谓 会 话 ， 指 的 是 从 客户 端 打开 与 服务 器 的 连接 并 发 出 请 求 到 服务 器 响应 客户 端 请 求 的 
全 过 程 。 会 话 跟踪 则 是 对 同一 个 用 户 对 服务 器 的 连续 的 请 求 和 接受 响应 的 监视 ， 由 于 客户 端 
与 服务 器 端 之 间 是 通过 HTTP 协议 进行 通信 的 ， 而 HITP 协议 本 身 是 无 状态 协议 ， 不 能 保存 
客户 的 信息 ， 即 一 次 响应 完成 之 后 连接 就 断 开 了 ， 在 下 一 次 的 请 求 时 ， 需 要 重新 建立 连接 ， 
等 到 建立 完 连接 后 还 需要 判断 是 否 是 同一 个 用 户 ， 所 以 ， 要 想 对 会 话 的 过 程 进行 监控 ， 最 好 
的 方法 就 是 通过 会 话 跟踪 技术 。 
具体 而 言 ， 会 话 跟踪 技术 主要 有 如 下 四 种 ; 

1) page 代表 与 一 个 页 面相 关 的 对 象 和 属性 。 一 个 页 面 由 一 个 编译 好 的 Java Servlet 类 
(可 以 带 有 任何 的 include 指令 , 但 是 没有 include 动作 ) 表示 。 这 既 包 括 Servlet 又 包括 被 编译 
成 Servlet 的 JSP 页 面 。 

2) request 代表 与 Web 客户 端 发 送 的 一 个 请 求 相关 的 对 象 和 属性 。 一 个 请 求 可 能 跨越 多 
个 页 面 ， 涉 及 多 个 Web 组 件 。 

3) session 代表 与 用 于 某 个 Web 客户 端的 一 个 用 户 体验 相关 的 对 象 和 属性 ， 一 个 Web 会 
话 经 常会 跨越 多 个 客户 端 请 求 。 
4) application 代表 与 整个 Web 应 用 程序 相关 的 对 象 和 属性 ， 实 质 上 是 跨越 多 个 Web 应 
用 程序 ， 包 括 多 个 页 面 、 请 求 和 会 话 的 一 个 全 局 作用 域 。 

6. 答案 : 多 线程 编程 是 一 项 非常 重要 的 技能 。 如 何 能 避免 死 锁 、 如 何 提高 多 线程 并 发 情 
况 下 的 性 能 是 非常 重要 的 ， 下 面 列 出 一 些 在 多 线程 编程 情况 下 的 指导 原则 : 

1) 如 果 能 用 volatile 代替 synchronized， 尽 可 能 用 volatile。 因 为 被 synchronized 修饰 的 方 
法 或 代码 块 在 同一 时 间 值 允许 一 个 线程 访问 ， 而 volatile 却 没有 这 个 限制 ， 因 此 使 用 
synchronized 会 降低 并 发 量 。 由 于 volatile 无 法 保证 原子 操作 ， 因 此 在 多 线程 的 情况 下 ， 只 有 
对 变量 的 操作 为 原子 操作 的 情况 下 才 可 以 使 用 volatile。 

2) 尽 可 能 减少 synchronized 块 内 的 代码 ， 只 把 临界 区 的 代码 放 到 synchronized 块 中 ， 尽 
量 避 免 用 synchronized 来 修饰 整个 方法 。 

3) 尽 可 能 给 每 个 线程 都 定义 一 个 线程 的 名 字 ， 不 要 使 用 匿名 线程 ， 这 样 有 利于 调试 。 

4) 尽 可 能 用 concurrent 容器 (ConcurrentHashMap ) 来 代替 synchronized 容器 (HashTable )。 
为 Synchronized 容器 使 用 synchronized 关键 字 通 过 对 整个 容器 加 锁 来 实现 多 线程 安全 的 , 性 
比较 低 。 而 Concurrent 容器 采用 了 更 加 细 粒 度 的 锁 ， 因 此 可 以 文 持 更 高 的 并 发 量 。 

5) 使 用 线程 池 来 控制 多 线程 的 执行 。 

三 、 数 据 库 设 计 题 目 

1. 答案 : 向 数据 库 中 插入 一 条 记录 用 的 是 insert 语句 ， 可 以 采用 如 下 两 种 写法 : 


乙 


起 团 
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1) insert into student(stu id, stu name) values(1,james')。 

2) insert into student values(1, james')。 

如 果 这 个 表 的 主键 为 stu_id, 并 且 采 用 数据 库 中 自 增 的 方式 生成 , 那么 在 插入 的 时 候 就 不 
能 显 式 地 指定 stu_id 这 一 列 ， 在 这 种 情况 下 ， 添 加 记录 的 写法 为 

insert into student(stu_name) values('James') 

2. 答案 : 在 数据 库 中 查询 用 到 的 关键 字 为 select， 由 于 student 表 中 只 存放 了 学 生 的 相关 
信息 ，course 表 中 只 存放 了 课程 的 相关 信息 ， 学 生 与 课程 是 通过 score 表 来 建立 关系 的 ， 一 种 
思路 是 : 首先 找到 名 字 为 Tom 的 学 生 的 stu_ id， 然 后 在 成 绩 表 〈score) 中 根据 stu_ id 找 出 该 
生 所 选课 程 的 c id， 最 后 就 可 以 根据 c_id 找 出 该 生 所 选 的 课程 。 

1) 可 以 使 用 下 面 的 select 语句 来 查询 : 


select c_ name from course where ¢ id in (Select ¢ id from Score where stu id in (Select std id 


from student where stu _ name='James')) 
2) 也 可 以 根据 题目 要 求 ， 依 据 三 张 表 的 关系 ， 直 接 执行 select 操作 ， 写 法 如 下 : 


select c_ name from student st, course c, Score sc Where st. Stu_ id=sc. stu id and sc. c_ id=c.c id 


and st. Stu_name='James' 

3) 当然 也 可 以 把 2) 的 写法 改 为 对 三 个 表 做 join 操作 。 

3. 答案 : 成 绩 都 存在 表 score 中 ， 而 课程 名 存储 在 表 course 中 ， 因 此 ， 需 要 访问 这 两 张 
表 来 找 出 课程 与 成 绩 ， 实 现 方法 如 下 : 


select c.c_name, s. Score from course c,score s Where s. stu id =4 and c.c id=s.c id 


5 是 遍 ” 某 知 名 游戏 软件 开发 公司 软件 工程 师 
笔试 题 


1. 答案 : C。 

分 析 : 本 题 考察 的 是 对 时 间 复 杂 度 知识 的 理解 。 

Tn)=2*T(n/2)+n=4*T(n/4)+ntn=8*T(n/8)t+ntntn=*…=n*T(1)+log(n)*n=O(nlog(n))。 所 以 ， 
选项 C 正确 。 

所 以 ， 本 题 的 答案 为 C。 

2. 答案 : D。 

分 析 : 本 题 考察 的 是 进程 知识 

进程 是 计算 机 中 的 程序 关于 某 数 据 集合 上 的 一 次 运行 活动 ， 是 系统 进行 资源 分 配 和 调度 
的 基本 单位 ， 是 操作 系统 结构 的 基础 。 它 主要 有 如 下 一 些 特性 : 

1) 动态 性 : 指 的 是 程序 的 一 次 执行 。 

2) 并 发 性 ， 多 个 进程 可 以 并 发 地 执行 。 

3) 独立 性 : 系统 进行 资源 分 配 和 调度 的 基本 单位 。 每 个 进程 都 可 以 独立 地 执行 。 

) 异步 性 : 由 于 进程 间 的 相互 制约 ， 使 进程 具有 执行 的 间断 性 ， 即 进程 按 各 自 独 立 的 、 

不 可 预知 的 速度 向 前 推进 。 
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5) 结构 性 : 进程 是 具有 结构 的 ， 由 程序 、 数 据 和 进程 控制 块 三 部 分 组 成 。 

程序 只 是 一 个 静态 的 代码 的 集合 。 有 具体 而 言 ， 二 者 有 如 下 区 别 : 

1) 程序 是 静态 的 ， 因 此 ， 只 要 程序 写 好 了 就 永远 存在 ， 而 进程 是 动态 的 ， 当 进程 执行 完 
成 后 就 消失 了 ， 因 此 ， 进 程 是 暂时 存在 的 。 

2) 进程 具有 并 发 性 ， 而 程序 没有 。 

3) 多 个 进程 可 以 用 同一 程序 执行 ， 同 理 ， 一 个 进程 也 可 以 执行 一 个 或 多 个 程序 。 

4) 进程 是 系统 进行 资源 分 配 和 调度 的 基本 单位 ， 而 程序 不 是 。 

通过 上 面 分 析 可 知 ， 程 序 和 进程 的 本 质 区 别 是 静态 和 动态 特征 。 

所 以 ， 本 题 的 答案 为 D。 

3. 答案 : B。 

分 析 : 本 题 考 察 的 是 对 正则 表达 式 和 自动 机 的 理解 。 

从 题目 中 的 自动 机 的 状态 转换 图 可 以 看 出 ， 这 个 自动 机 可 以 识别 如 下 几 种 表达 式 : 

1) 0 个 或 多 个 0。 

2) 0 个 或 多 个 如 下 的 表达 式 : 先 识别 0 或 1， 接着 识别 一 个 0; 也 就 是 说 ， 识 别 00 串 或 
10 串 ， 对 于 00 串 而 言 ， 与 1) 是 相同 的 。 

3) 1) 和 2) 组 合 的 表达 式 。 

综 上 所 述 ， 这 个 自动 机 可 以 识别 0 个 或 多 个 10 串 以 及 0 个 或 多 个 0 的 组 合 。 

此 可 见 ， 选 项 B 满足 条 件 ， 所 以 ， 选 项 B 正确 。 题 目 中 的 自动 机 可 以 识别 100 串 ， 而 
选项 A、 选 项 C 和 选项 D 都 无 法 识别 。 所 以 ， 选 项 A、 选 项 C 与 选项 D 都 错误 。 

所 以 ， 本 题 的 答案 为 了 B。 

4. 答案 : D。 

分 析 : 本 题 考察 的 是 对 IPv6 的 理解 。 

IP 地 址 是 Internet 上 主机 或 路 由 器 的 数字 标识 ， 用 来 唯一 地 标识 该 设备 。IPv4 (Internet 
Protocol version 4， 互 联网 协议 版 本 4) 是 一 个 被 广泛 使 用 的 互联 网 协议 ， 而 IPv6 是 下 一 版 本 
的 互联 网 协议 。 随 着 互联 网 的 迅速 发 展 ，IPv4 定义 的 有 限 地 址 空间 将 被 耗 尽 ， 地 址 空间 的 不 
足 必 将 妨碍 互联 网 的 进一步 发 展 。 为 了 扩大 地 址 空间 ， 拟 通过 IPv6 重新 定义 地 址 空间 。 

IPv6 采用 128bit〈 合 16B) 地 址 长 度 ， 几 乎 可 以 不 受 限 制 地 提供 地 址 。IPv6 不 仅 解决 了 
地 址 短缺 的 问题 ， 还 考虑 了 在 IPv4 中 存在 的 端 到 端 IP 连接 、 服 务 质量 、 安 全 性 、 多 播 、 移 
动 性 及 即 插 即 用 等 问题 。 所 以 ， 选 项 DD 正确 。 

所 以 ， 本 题 的 答案 为 D。 

5. 答案 : C。 

分 析 : 本 题 考察 的 是 对 RARP 协议 的 理解 。 

ARP (Address Resolution Protocol， 地 址 解析 协议 ) 是 一 个 位 于 TCP/P 协议 栈 中 的 低层 
协议 ， 它 用 于 映射 计算 机 的 物理 地 址 与 网 络 IP 地 址 。 在 Internet 分 布 式 环境 中 ， 每 个 主机 都 
被 分 配 了 一 个 32bit 的 网 络 地 址 ， 此 时 就 存在 计算 机 的 IP 地 址 与 物理 地 址 之 间 的 转换 问题 。 
ARP 协议 所 要 做 的 工作 就 是 在 主机 发 送 帧 前 ， 根 据 目标 IP 地 址 获取 MAC 地 址 ， 以 保证 通信 
过 程 的 顺畅 。 

其 具体 过 程 如 下 : 首先 ， 每 台 主 机 都 会 在 自己 的 ARP 缓冲 区 中 建立 一 个 ARP 列表 ， 用 
于 存储 卫 地 址 与 MAC 地 址 的 对 应 关系 ; 然后 ， 当 源 主 机 需要 将 一 个 数据 包 发 送 到 目标 主机 
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时 ,会 首先 检查 自己 的 ARP 列表 是 否 存在 该 卫 地 址 对 应 的 MAC 地址 ， 如 果 存 在 ， 则 直接 将 
数据 包 发 送 到 该 MAC 地 址 ， 如 果 不 存在 ， 就 向 本 地 网 段 发 起 一 个 ARP 请 求 的 广播 包 ， 用 于 
查询 目标 主机 对 应 的 MAC 地 址 ， 此 ARP 请 求 数 据 包 里 包括 源 主机 的 了 P 地 址 、 硬件 地 址 以 及 
目标 主机 的 人 P 地 址 等 ， 当 网 络 中 所 有 的 主机 收 到 这 个 ARP 请 求 之 后 ， 会 检查 数据 包 中 的 目 
的 全 是 否 与 自己 的 卫 地 址 一 致 ， 如 果 不 同 就 忽略 此 数据 包 ， 如 果 相 同 ， 该 主机 会 将 发 送 端 
的 MAC 地 址 与 卫 地 址 添加 到 自己 的 ARP 列表 中 , 如 果 ARP 列表 中 已 经 存在 该 卫 地址 的 相 
关 信 息 ， 则 将 其 覆盖 掉 ， 接 着 给 源 主机 发 送 一 个 ARP 响应 包 ， 告 诉 对 方 自己 是 它 所 需要 查找 
的 MAC 地 址 ; 最 后 源 主机 收 到 这 个 ARP 响应 包 后 ， 将 得 到 的 目的 主机 的 卫 地 址 和 MAC 地 
址 添加 到 自己 的 ARP 列表 中 ,并 利用 此 信息 开始 数据 的 传输 ， 如 果 源 主机 一 直 没 有 收 到 ARP 
响应 包 ， 则 表示 ARP 查询 失败 。 

RARP (Reverse Address Resolution Protocol， 反 向 地 址 解析 协议 ) 与 ARP 工作 方式 相反 。 
RARP 发 出 要 反 向 解析 的 物理 地 址 并 希望 返回 其 对 应 的 卫 地 址 ， 应 答 包 括 由 能 够 提供 所 需 信 
息 的 RARP 服务 器 发 出 的 卫 地 址 。RARP 获取 卫 地 址 的 过 程 如 下 : 主机 发 起 一 个 RARP 请 
求 的 广播 包 ， 用 于 查询 主机 的 卫 地 址 ， 这 个 广播 包 中 包含 了 主机 的 MAC 地 址 ;， 网络 中 的 
RARP 服务 器 收 到 这 个 RARP 请 求 后 ， 检 查 其 RARP 列表 ， 查 询 这 个 MAC 地 址 对 应 的 全 地 
址 ， 如 果 找 到 ， 则 发 送 响 应 包 给 请 求 主 机 ， 否 则 ， 不 做 任何 响应 ; 源 主机 获取 到 这 个 IP 地 址 
后 ， 就 可 以 用 这 个 卫 地 址 进行 通信 。 所 以 ， 选 项 C 正确 。 

所 以 ， 本 题 的 答案 为 C。 

二 、 简 答题 

1. 答案 : 乙 至 少 猜 14 次 才 可 以 准确 猜 出 这 个 数字 ， 在 这 种 策略 下 ， 乙 猜 的 第 一 个 数字 
是 14。 

分 析 : 数字 所 在 区 间 为 [1,100]， 乙 在 猜测 数字 时 ， 存 在 以 下 三 种 可 能 性 ; 

1) 直接 猜 中 。 

2) 猜测 数字 大 于 真实 值 。 

3) 猜测 数字 小 于 真实 值 。 

以 下 将 分 别针 对 这 三 种 不 同 的 情况 进行 分 析 。 第 1) 种 直接 猜 中 的 情况 概率 很 低 ， 只 有 
百 分 之 一 ， 不 具有 代表 意义 。 第 2) 种 情况 ， 乙 猜测 的 数字 的 值 比 真实 值 大 ， 此 时 没有 提示 ， 
假设 待 猜测 的 数字 的 值 为 N2， 乙 猜测 的 数字 的 值 为 N1， 很 显然 ， 在 本 情况 下 ，N1>N2， 此 
时 ， 为 了 找到 N2， 只 能 逐一 在 [LN1- 即 1 和 N2 和 N1-1。 只 有 第 3) 种 情况 ， 
会 存在 提示 ， 假 设 竺 猜测 的 数字 的 值 为 N2， 乙 猜测 的 数字 的 值 为 NI1， 很 显然 ， 在 本 情况 下 ， 
N1<N2， 根 据 提示 可 知 ， 可 以 继续 在 [N1+1， mip et eh 

所 以 ， 对 于 第 2) 种 情况 ， 一 共 需 要 猜测 的 次 数 为 N1-1+1=N1 次 (其 中 ，N1-1 表示 需 
要 在 [1,N1-1] 之 间 逐 一 取 值 ，1 表示 进行 第 一 次 测试 )。 对 于 第 3) 种 情况 ， 如 果 第 一 次 猜 的 数 
字 小 于 真实 值 ， 但 第 二 次 猿 的 数字 大 于 真实 值 ， 此 时 需要 尝试 的 总 次 数 是 [N1+1,N2-1] 的 元 素 
个 数 加 2 (加 2 是 N2 和 NI1 本 身 猜 用 掉 一 次 )， 即 为 N2-N1+1 次 ， 根 据 “ 每 次 猜 错 后 ， 尝 试 
猜测 的 总 次 数 相等 ”思想 ， 有 N1=N2-N1+1， 可 知 N2=2N1-1， 增 量 为 N1-1。 类 似 地 ， 前 两 
次 猪 得 偏 小 ， 但 第 三 次 猜 大 ， 尝 试 总 次 数 为 [N2+1,N3-1] 的 元 素 个 数 加 3， 即 N3-N2+2， 那 么 
有 N3 N2+2=N1, N3=N2+N1-2， 增 量 为 N1-2…… 依 次 类 推 ， 增 量 是 随 着 猜测 次 数 的 增加 而 逐 1 
地 减少 。 设 最 后 一 次 猜测 为 k， 则 Nk=NI+GNI-D+N1-2)+…+1，Nk 是 等 于 或 大 于 100 的 第 一 个 
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数 ， 根 据 等 差 数 列 求 和 公式 可 以 算出 NI1=14，N2=27，N3=39…(14，27，39，50，60，69，77， 
84, 90, 95, 99)。 

序列 是 14、27、39、50、60、69、77、84、90、95、99。 因 为 无 论 第 几 次 猪 大 了 ， 最 终 
的 总 次 数 总 是 14。 

2. 答案 : Java 语言 提供 了 两 种 错误 的 处 理 类 ， 分 别 为 Error 和 Exception， 且 它们 拥有 共 
同 的 父 类 :， Throwable。 

Error 表示 程序 在 运行 期 间 出 现 了 非常 严重 的 错误 ， 并 且 该 错误 是 不 可 恢复 的 。 由 于 这 属 
于 JVM 层次 的 严重 错误 ， 所 以 ， 这 种 错误 会 导致 程序 终止 执行 。 此 外 ， 编 译 器 不 会 检查 Error 
是 否 被 处 理 ， 因 此 ， 在 程序 中 不 推荐 去 捕获 Error 类 型 的 异常 ， 主 要 原因 是 运行 时 异常 多 是 
于 逻辑 错误 导致 的 ， 属 于 应 该 解决 的 错误 ， 也 就 是 说 ， 一 个 正确 的 程序 中 是 不 应 该 存在 Error 
的 。OutOfMemoryError、ThreadDeath 和 NoClassDefFoundError 等 都 属于 错误 ， 当 这 些 错误 发 
生 时 ，JVM 一 般 会 选择 将 线程 终止 。 
Exception 表示 可 恢复 的 异常 ， 是 编译 器 可 以 捕捉 到 的 。 它 包含 两 种 类 型 : 运行 时 异常 
(Runtime Exception) 和 检查 异常 〈Checked Exception )。 

1) 检查 异常 是 在 程序 中 最 经 常 磁 到 的 异常 ， 比 如 最 常见 的 IO 异常 和 SQL 异常 。 对 于 这 
种 异常 ， 都 发 生 在 编译 阶段 ，Java 编译 器 强制 程序 去 捕获 此 类 型 的 异常 ， 即 把 可 能 会 出 现 这 
些 异 常 的 代码 放 到 try 块 中 ， 把 对 异常 的 处 理 的 代码 放 到 catch 块 中 。 这 种 异常 一 般 在 如 下 几 

异常 的 发 生 并 不 会 导致 程序 出 错 ， 进 行 处 理 后 可 以 继续 执行 后 续 的 操作 。 例 如 ， 当 连 

接 数 据 库 失败 后 ， 可 以 重新 连接 后 进行 后 续 操 作 。 

@ 程序 依赖 于 不 可 靠 的 外 部 条 件 ， 例 如 系统 IO。 

儿 个 检查 异常 如 下 : SQLException、IOException 和 UnknownHostException 。 

2) 对 于 运行 时 异常 ， 编 译 器 没有 强制 对 其 进行 捕获 并 处 理 。 如 果 不 对 这 种 异常 进行 处 
理 ， 当 出 现 这 种 异常 时 ， 会 由 JVM 来 处 理 。 在 Java 语言 中 ， 最 常见 的 运行 时 异常 有 如 下 几 
种 : NullPointerException 〈 空 指针 异常 )、ArrayStoreException (数据 存储 异常 )、 
ClassCastException (类 型 转换 异常 )、InexOutOfBoundException (数组 越界 异常 )、 
BufferOverflowException 〈 缓 冲 区 溢出 异常 ) 及 ArithmeticException (算术 异常 ) 等 。 

它们 的 继承 关系 如 图 20 所 示 。 


图 20 噶 常 的 继承 关系 
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1 于 有 很 多 种 检查 异常 ， 这 里 只 画 了 IOException 作为 代表 。 
3、 答 案 : 参见 真题 6 中 简 答题 5。 

4. 答案 ;Java 语言 是 一 种 具有 动态 性 的 解释 型 语言 ， 类 只 有 被 加 载 到 JVM 中 后 才能 运 
行 。 当 运行 程序 的 时 候 ，JVM 会 将 编译 生成 的 .class 文件 按照 需求 和 一 定 的 规则 加 载 到 内 存 
中 ， 并 组 织 成 为 一 个 完整 的 Java 应 用 程序 。 这 个 加 载 过 程 是 由 加 载 器 来 完成 的 ， 有 具体 而 言 ， 
就 是 由 ClassLoader 和 它 的 子 类 来 实现 的 。 类 加 载 器 本 身 也 是 一 个 类 ， 其 实质 是 将 类 文件 从 硬 
盘 读 取 到 内 存 中 。 

类 的 加 载 方式 分 为 隐 式 装载 与 显 式 装载 两 种 。 隐 式 装 载 指 的 是 程序 在 使 用 new 等 方式 创 
建 对 象 时 ， 会 隐 式 地 调用 类 的 加 载 器 将 对 应 的 类 加 载 到 JVM 中 。 显 式 装 载 指 的 是 通过 直接 调 
用 class.forName0 方 法 将 所 需 的 类 加 载 到 JVM 中 。 

任何 一 个 工程 项 目 都 是 由 许多 个 类 组 成 的 ， 当 程序 启动 的 时 候 ， 上 只 把 需要 的 类 加 载 到 
JVM 中 ， 其 他 的 类 只 有 在 被 使 用 到 的 时 候 才 会 被 加 载 ， 采 用 这 种 方法 ， 一 方面 可 以 加 快 加 载 
速度 ， 另 一 方面 可 以 节约 程序 运行 过 程 中 对 内 存 的 开销 。 此 外 ， 在 Java 语言 中 ， 每 个 类 或 接 
口 都 对 应 一 个 .class 文件 ， 这 些 文件 可 以 被 看 成 是 一 个 个 可 以 被 动态 加 载 的 单元 ， 因 此 ， 当 只 
有 部 分 类 被 修改 时 ， 只 需要 重新 编译 变化 的 类 即 可 ， 而 不 需要 重新 编译 所 有 的 文件 ， 因 此 ， 
加 快 了 编译 速度 。 

在 Java 语言 中 ， 类 的 加 载 是 动态 的 ， 它 并 不 会 一 次 性 将 所 有 类 全 部 加 载 后 再 运行 ， 而 是 
保证 程序 运行 的 基础 类 (例如 基 类 ) 完全 加 载 到 JVM 中 ， 至 于 其 他 类 ， 则 在 需要 的 时 候 才 加 
载 。 在 Java 语言 中 ， 可 以 把 类 分 为 三 类 : 系统 类 、 扩 展 类 和 自 定义 类 。Java 语言 针对 这 三 种 
不 同 的 类 提供 了 三 种 类 型 的 加 载 器 ， 这 三 种 加 载 器 的 关系 如 下 : 


Bootstrap Loader -负责 加 载 系统 类 (jre/lib/rt.jar 的 类 ) 
| 
- - ExtClassLoader -负责 加 载 扩 展 类 (jar/lib/ext/*.jar 的 类 ) 
| 
- - AppClassLoader -负责 加 载 应 用 类 (classpath 指定 的 目录 或 jar 中 的 类 ) 

以 上 这 三 个 类 是 怎么 协调 工作 来 完成 类 的 加 载 呢 ? 其 实 , 它们 是 通过 委托 的 方式 实现 的 。 
具体 而 言 ， 就 是 当 有 类 需要 被 加 载 时 ， 类 装载 器 会 请 求 父 类 来 完成 这 个 载 入 工作 ， 父 类 会 使 
用 其 自己 的 搜索 路 径 来 搜索 需要 被 载 入 的 类 ， 如 果 搜 索 不 到 ， 才 会 由 子 类 按照 其 搜索 路 径 来 
搜索 待 加 载 的 类 。 下 例 可 以 充分 说 明 加 载 器 的 工作 原理 : 


public class TestLoader 


{ 


public static void main(String[] args) throws Exception 


{ 


用 class 加 载 器 
ClassLoader clApp = TestLoader.class.getClassLoader(); 
tem.out.println(clApp); 


// 调 
S 

由 用 上 一 层 Class 加 载 器 

S 


// 调 

ClassLoader clExt = clApp.getParent(); 
Sy 
// 调 


tem.out.println(clExt); 


用 根部 Class 加 载 器 
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ClassLoader clBoot = clExt.getParent(); 
System.out.println(clBoof); 


1 
了 
上 例 的 运行 结果 大 


sun.misc.Launcher$AppClassLoader@19821f 
sun.misc.Launcher$ExtClassLoader@addbf]l 
null 


从 上 例 可 以 看 出 ，TestLoader 类 是 由 AppClassLoader 来 加 载 的 。 男 外 需要 说 明 的 一 点 是 ， 
由 于 Bootstrap Loader 是 使 用 C++ 语言 来 实现 的 ， 因 此 ， 在 Java 语言 中 ， 是 看 不 到 它 的 ， 所 
以 ， 此 时 程序 会 输出 null。 

类 加 载 的 主要 步骤 分 为 以 下 三 步 : 

1) 装载 : 根据 查找 路 径 找 到 相对 应 的 class 文件 ， 然 后 导入 。 

2) 链接 : 链接 又 可 以 分 为 三 个 小 的 步骤 ， 有 具体 如 下 : 

Q 检查: 检查 竺 加 载 的 class 文件 的 正确 性 。 

@ 准备 : 给 类 中 的 静态 变量 分 配 存储 空间 。 

@) 解析 : 将 符号 引用 转换 成 直接 引用 (这 一 步 是 可 选 的 )。 

3) 初始 化 : 对 静态 变量 和 静态 代码 块 执 行 初始 化 工作 。 

5. 答案: 参见 真题 2 中 不 定 项 选择 16。 

6. 答案 : 不 存在 问题 ， 输 出 结果 为 3423。 

分 析 : 本 题 考察 的 是 对 finally 的 理解 。 
在 Java 语言 的 异常 处 理 中 ，finally 语句 块 的 作用 是 为 了 保证 无 论 出 现 什么 情况 ，finally 
块 里 的 代码 一 定 会 被 执行 。 由 于 当 程 序 执行 到 retum 的 时 候 ， 就 意味 着 结束 对 当前 函数 的 调 
用 并 跳出 这 个 函数 体 ， 任 何 语句 要 执行 都 只 能 在 returm 前 执行 (除非 碰 到 exit 函数 )， 因 此 ， 
finally 块 里 的 代码 也 是 在 return 前 执行 的 。 此 外 ， 如 果 try-finally 或 者 catch-finally 中 都 有 
return， 则 finally 块 中 的 retum 语句 将 会 覆盖 别处 的 return 语句 ， 最 终 返回 到 调用 者 那里 的 是 
finally 语句 块 中 return 的 值 。 下 面 通过 一 个 例子 (示例 1) 来 说 明 这 个 问题 。 


public class Test 


{ 
public static inttestFinally() 
{ 
try 
{ 


return 1; 
}catch(Exception e) 


{ 

return 0; 
}finally 
{ 


System.out.println("execute finally"); 
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} 
} 


public static void main(String[] args) 


{ 
int result=testFinally(); 
System.out.printIn(resultb); 


} 


星 序 的 运行 结果 为 


execute finally 
1 


从 上 面 这 个 例子 中 可 以 看 出 ， 在 执行 return 语句 前 确实 执行 了 finally 块 中 的 代码 。 紧 接 
着 ， 在 finally 块 里 面 放置 个 retur 语句 ， 例 子 〈 示 例 2) 如 下 所 示 : 


> 


public class Test 
{ 
public static inttestFinally() 
{ 
try 
{ 
return 1; 
}catch(Exception e) 
{ 
return 0; 
}finally 
{ 
System.out.println("execute finally"); 
return 3; 
} 
} 
public static void main(String[] args) 
{ 
int result=testFinally(); 
System.out.printIn(result); 
} 
} 
程序 的 运行 结果 大 
execute finally 
3 


从 以 上 运行 结果 可 以 看 出 ， 当 finally 块 中 有 return 语句 时 ， 将 会 覆盖 函数 中 其 他 return 
语句 。 此 外 ， 由 于 在 一 个 方法 内 部 定义 的 变量 都 存储 在 栈 中 ， 当 这 个 函数 运行 结束 后 ， 其 对 
应 的 栈 就 会 被 回收 ， 此 时 ， 在 其 方法 体 中 定义 的 变量 将 不 存在 了 ， 因 此 ，retur 在 返回 时 不 是 
直接 返回 变量 的 值 ， 而 是 复制 一 份 ， 然 后 返回 。 因 此 ， 对 于 基本 类 型 的 数据 ， 在 finally 块 中 
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改变 return 的 值 对 返回 值 没有 任何 影响 ， 而 对 于 引用 类 型 的 数据 ， 就 有 影响 。 
下 面 通 过 一 个 例子 (示例 3) 来 说 明 这 个 问题 。 


public class Test 
{ 
public static int testFinally1() 
' 
int result=1; 
try 
{ 
result=2; 
return result; 
}catch(Exception e) 
{ 
return 0; 
}finally 
{ 
result=3; 
System.out.println("execute finally2"); 


} 
public static StringBuffer testFinally2() 
{ 
StringBuffer s=new StringBuffer("Hello"); 
try{ 
return s; 
}catch(Exception e) 
{ 
return null; 
}finally 
{ 
s.append(" World"); 
System.out.println("execute finally2"); 


} 


public static void main(String[] args) 

{ 
intresultVal=testFinally10; 
System.out.println(resultVal); 
StringBufferresultRef—testFinally2(); 
System.out.println(resultRef); 


} 


程序 的 运行 结果 六 


execute finally1l 
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2 
execute finally2 
Hello World 


程序 在 执行 到 return 语句 时 , 会 首先 将 返回 值 存储 在 一 个 指定 的 位 置 ， 然后 去 执行 finally 
代码 块 ， 最 后 再 返回 。 在 方法 testFinallyl 中 调用 return 前 ， 首 先 将 result 的 值 1 存储 在 一 个 
指定 的 位 置 ， 然 后 再 去 执行 finally 块 中 的 代码 ， 此 时 修改 result 的 值 不 会 影响 到 程序 的 返回 
结果 。testFinally2 中 ,在 调用 return 前 , 首先 将 s 存储 到 一 个 指定 的 位 置 ， 由 于 s 为 引用 类 型 ， 
因此 ， 在 finally 块 中 修改 s 将 会 修改 程序 的 返回 结果 。 

引申 ， 出 现在 Java 程序 中 的 finally 代码 块 是 否 一 定 会 执行 ? 

答案 : 不 一 定 会 执行 。 

下 面 给 出 两 个 finally 代码 块 不 会 执行 的 例子 。 

1) 当 程 序 在 进入 try 语句 块 之 前 就 出 现 异常 时 ， 会 直接 结束 ， 不 会 执行 finally 块 中 的 代 
码 。 如 下 例 所 示 : 


public class Test 
{ 
public static void testFinally() 
{ 
inti=5/0; 
try{ 
System.out.println("try block"); 
}catch(Exception e) 
{ 
System.out.println("catch block"); 
}finally 
{ 
System.out.println("finally block"); 
} 
} 
public static void main(String[| args){ 
testFinally(); 
} 
} 
程序 的 运行 结果 为 


Exception in thread "main" java.lang.ArithmeticException: / by zero 
at Test.testFinally(Test.java:3) 
at Test.main(Test.java:13) 


程序 在 执行 inti=5/0 时 会 抛 出 异常 ， 导 致 没有 执行 try 块 ， 因 此 ，finally 块 也 就 不 会 被 


2) 当 程序 在 try 块 中 强制 退出 时 ， 也 不 会 去 执行 finally 块 中 的 代码 ， 如 下 例 所 示 : 


public class Test 


{ 
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public static void testFinally() 
{ 
try 
{ 
System.out.println("try block");; 
System.exit(0); 
}catch(Exception e) 
{ 
System.out.println("catch block"); 
}finally 
{ 
System.out.println("finally block"); 
} 
} 
public static void main(String[] args) 
{ 
testFinally(); 
} 
} 
程序 的 运行 结果 为 
try block 


上 例 在 try 块 中 通过 调用 System.exit(0) 方 法 强制 退出 了 程序 ， 


代码 没有 被 执行 。 


因此 ， 导 致 fmnally 块 中 的 


从 上 面 分 析 可 以 看 出 : 在 try/catch/finally 语句 执行 时 , try 块 首先 执行 ， 如果 有 异常 发 生 ， 
则 进入 catch 块 来 匹配 异常 ， 当 匹配 成 功 后 则 执行 catch 块 中 的 代码 ， 不 管 有 无 异常 发 生 ， 都 
会 执行 finally 块 的 代码 〈 就 算 catch 块 中 有 return 语句 ，finally 块 仍然 会 执行 )， 当 有 异常 发 


生 后 ，catch 和 finally 块 进行 处 理 后 程序 就 结束 了 ， 就 算 finally 块 后 面 有 


如 果 没 有 异常 发 生 ， 则 执行 完 finally 块 的 代码 后 ， 后 面 的 代码 还 会 继续 执行 。 


对 于 本 题 而 言 ， 在 调用 foo(0) 方 法 时 ， 没 有 异常 ， 


因 


代码 也 不 会 执行 了 ， 


此 ， 直 接 执行 finally 块 后 面 的 代码 


块 , 方法 的 返回 值 为 “34”; 在 调用 foo(1) 方 法 时 , 产生 异常 , 因此 , 只 会 执行 catch 块 和 finally 


块 中 的 代码 ， 方 法 返 
7. 答案 : 不 存在 问题 ， 输 出 结果 为 


加 | 


static A 
static B 
Im A class 
HelloA 
Im B class 
HelloB 


分 析 : 本 题 考察 的 是 对 Java 不 同 代码 块 初始 化 先后 顺序 的 理解 。 


在 Java 语言 中 ， 当 实例 化 对 象 时 ， 对 象 所 在 类 的 所 有 


值 为 “23”。 因 此 ， 这 个 程序 的 输出 结果 为 3423。 


成 员 变量 首先 要 进行 初始 化 ， 


当 所 有 类 成 员 完成 初始 化 后 ， 才 会 调用 对 象 所 在 类 的 构造 函数 创建 对 象 。 


只 有 
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Java 程序 的 初始 化 一 般 遵 循 以 下 三 个 原则 《以 下 三 原则 优先 级 依次 递减 ) 


1) 静态 对 象 ( 变 量 ) 优先 于 非 静 态 对 象 〈 变 量 ) 初始 化 ， 其 中 ， 静 态 对 象 〈 变 量 ) 只 初 


台 化 一 次 ， 而 非 静态 对 象 〈 变 量 ) 可 能 会 初始 化 多 次 。 
2) 父 类 优先 于 子 类 进行 初始 化 。 


3) 按照 成 员 变 量 定义 顺序 进行 初始 化 。 即 使 变量 定义 散布 于 方法 定义 之 中 ,它们 依然 在 


任何 方法 〈 包 括 构造 函数 ) 被 调用 之 前 先 初始 化 。 
Java 程序 初始 化 工作 可 以 在 许多 不 同 的 代码 块 中 完成 《例如 静态 代码 块 、 


构造 函数 等 )， 


它们 执行 的 顺序 如 下 : 父 类 静态 变量 、 父 类 静态 代码 块 、 子 类 静态 变量 、 子 类 静态 代码 块 、 


父 类 非 静 态 变 量 、 父 类 非 静 态 代 码 块 、 父 类 构造 函数 、 子 类 非 静态 变量 、 子 类 非 静态 代码 块 


以 及 子 类 构造 函数 。 
根据 以 上 分 析 可 知 ， 本 题 中 ， 当 代码 运行 时 ， 首 先 执行 父 类 静态 代码 块 ， 


输出 static A; 


其 次 执行 子 类 静态 代码 块 ， 输 出 static B;， 再 执行 父 类 非 静态 代码 块 ， 输 出 Pm A class; 接着 
执行 父 类 构造 函数 ， 输 出 HelloA; 然后 执行 子 类 非 静态 代码 块 ， 输 出 Pm B class; 最 后 执行 


子 类 构造 函数 ， 输 出 HelloB。 
8. 答案 : 不 存在 问题 ， 输 出 结果 为 0。 
分 析 : 本 题 考 察 的 是 对 值 传递 和 后 置 ++ 操 作 的 理 


zs 


让 


本 题 中 ， 首 先 对 方法 increase 的 调用 是 值 传递 ， 因 此 ， 对 形 参 的 修改 不 会 影响 到 实 参 的 


的 执行 结果 。 
后 置 it+ 是 在 程序 执行 完毕 后 自 增 ， 实 现 原理 为 

1) 把 变量 i 的 值 取 出 来 ， 放 在 一 个 临时 变量 〈 先 记 作 tmp) 里 。 
2) 变量 i 执行 自 增 操作 。 
3) 把 临时 变量 tmp 的 值 作为 自 增 运 算 的 结果 返回 。 
i=it+ 的 实现 原理 实际 上 等 价 于 下 面 的 一 段 (3 行 ) 代码 : 
1) tmp=i; // 把 i 的 值 保存 到 tmp，tmp=0 

2) i=i+l; /执行 自 增 操作 ，i=1 

3) i=tmp; // 自 增 操作 的 返回 值 0 赋值 给 1， 此 时 i=0 


地 


从 上 面 分 析 可 以 发 现 ， 在 执行 完 语 句 二 计 + 后 ， 变 量 i 的 值 保持 不 变 。 因 此 ， 程 序 的 输出 


结果 为 0。 
9. 答案 : 不 存在 问题 ， 输 出 结果 为 goodandgbc。 


str 来 说 ,修改 的 是 引用 本 身 ， 也 就 是 说 ,修改 的 是 引用 的 值 ， 而 不 是 修改 了 引 


形 参 引 用 的 值 是 实 参 引 用 值 的 一 个 副本 ; 从 这 个 角度 来 讲 ， 引 用 传递 是 通过 传递 引用 的 值 来 


实现 的 ， 可 以 理解 为 值 传递 ， 对 引用 本 喘 的 修改 对 实 参 是 不 可 见 的 。 
10. 答案 : 不 存在 问题 ， 输 出 结果 为 packagel.Test。 
分 析 : 本 题 考察 的 是 对 getClass0 方 法 的 理解 。 


值 , 在 执行 完 increase 方法 的 调用 后 , main 方法 中 i 的 值 仍然 为 0。 本题 的 难点 是 要 理解 二 it++ 


在 调用 change 方法 时 ，str 和 ch 传递 的 都 是 引用 ， 在 方法 中 修改 了 ch 指向 对 象 的 内 容 ， 
由 于 形 参 与 实 参 指 向 相同 的 对 象 ， 因 此 ， 通 过 形 参 对 对 象 内 容 的 修改 对 实 参 是 可 见 的 。 对 于 


用 指向 的 内 容 。 


日 这 个 方法 来 获 


Java 语言 提供 了 获取 类 名 的 方法 : getClass0.getName0， 开 发 人 员 可 以 调 月 
取 类 名 ， 代 码 如 下 示例 1): 


216 


public class Test 
{ 
public void test() 
{ 
System.out.printlin(this.getClass().getName()); 
} 
public static void main(String[] args) 
{ 
new Test().test(); 
} 
} 
程序 的 运行 结果 为 
Test 


通过 以 上 例子 的 运行 结果 , 是否 可 以 得 出 这 样 一 个 结论 ;通过 调用 父 类 的 getClassO.getName() 
方法 来 获取 父 类 的 类 名 是 否 可 行 呢 ? 为 了 解答 这 个 问题 ， 首 先 来 做 一 个 实验 。 给 出 下 面 的 程序 
(示例 2)。 


class A{} 
public class Test extends A 


{ 


public void test() 


{ 
System.out.printIn(super.getClass().getName()); 
} 


public static void main(String[] args) 


{ 


new Test().test(); 
} 
} 


程序 的 运行 结果 为 
Test 


为 什么 输出 的 结果 不 是 “A” 而 是 “Test” 呢 ?主要 原因 在 于 Java 语言 中 任何 类 都 继承 自 
Object 类 ，getClass0 方 法 在 Object 类 中 被 定义 为 final 与 native， 而 子 类 不 能 履 盖 该 方法 。 因 
此 ，this.getClass0 和 supergetClass0 最 终 都 调用 的 是 Object 类 中 的 getClass(0 方 法 。 而 Object 
的 getClass0 方 法 的 释义 是 : 返回 此 Object 的 运行 时 类 。 由 于 在 上 面 代码 中 实际 运行 的 类 
是 Test 而 不 是 A， 因 此 ， 程 序 输出 结果 为 Test。 那 么 如 何 才能 在 子 类 中 得 到 父 类 的 名 字 呢 ? 
可 以 通过 Java 的 反射 机 制 ， 使 用 getClass0.getSuperclassO.getNameO0。 代 人 码 如 下 《示例 3 ): 

class A{} 


public class Test extends A 


public void test() 
{ 
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System.out.println(this.getClass().getSuperclass().getName(O); 


} 


public static void main(String[] args) 


{ 


new Test().test(); 


对 于 本 题 而 言 ， 调 用 supergetClass0.getName0O 也 会 得 到 当前 运行 类 的 名 字 ， 即 
packagel.Test。 


1. 答案 : 最 简单 的 方法 就 是 遍历 两 个 集合 ， 针 对 集合 中 的 每 个 元 素 判 断 是 否 有 交集 ， 如 
果 有 ， 则 求 出 它们 的 交集 ， 实 现代 码 如 下 : 


i 


import java.util.*; 
class MySet 
{ 
private int min; 
private int max; 


public MySet(int min, int max) 
{ 
this.min=min; 
this.max=max; 
} 
public int getMin() 
{ 
return min; 
} 
public void setMin(int min) 
{ 
this.min = min; 
} 
public int getMax() 
{ 
return max; 
} 


public void setMax(int max) 


{ 


this.max = max; 


} 


public class Test 


{ 
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private static MySet getIntersection(MySet sl,MySet s2) 


{ 
if(sl.getMin()<s2.getMin()) 
{ 
if(sl.getMax()<s2.getMin()) 
return null; 
else if(sl.getMax()<=s2.getMax()) 
return new MySet(s2.getMin(),s1.get Max()); 
else 
return new MySet(s2.getMin(),s2.get Max()); 
} 
else if(sl.getMin()<=s2.getMax()) 
{ 
这 sl.getMax()<=s2.getMax()) 
return new MySet(sl.getMin(),s1.get Max()); 
else 
return new MySet(sl.getMin(),s2.get Max()); 
} 
else 
{ 
return null; 
} 
} 


public static ArrayList<MySet> getIntersection(ArrayList<MySet> 11,ArrayList<MySet> 12) 
{ 
ArrayList<MySet> result=new ArrayList<MySet>(); 
for(int 1=0;1<]11.size();i++) 
for(int j=0;]j<12.size();j++) 


{ 
MySet s=getIntersection(l1.get(1),12.getQ)); 
if(s!=null) 
result.add(s); 
} 
return result; 


public static void main(String[] args) 

{ 
ArrayList<MySet> ll=new ArrayList<MySet>(); 
ArrayList<MySet> 12= new ArrayList<MySet>(); 
ll.add(new MySet(4,8)); 
ll.add(new MySet(9,13)); 


12.add(new MySet(6,12)); 
ArrayList<MySet> result=getIntersection(l1,12); 
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for(int 1=0;i<result.size();i++) 
System.out.println("["+result.get(i).get Min()+","+result.get(i).get Max() + "] "); 


} 


} 


程序 的 运行 结果 为 
[6,8] 
[9,12] 
显然 ， 以 上 这 个 算法 的 时 间 复 杂 度 为 O(n^2)。 
上 述 这 种 方法 显然 没有 用 到 集合 有 序 的 特点 ， 因 此 ， 它 不 是 最 佳 的 方法 。 假 设 两 个 集合 
为 S1，s2。 当 前 比较 的 集合 为 s1[ 和 和 s2[]， 其 中 ，i 与 j 分 别 表示 的 是 集合 sl 与 82 的 下 标 。 
可 以 分 为 如 下 几 种 情况 ; 
1) 
slTj] 
s2[j] 
在 这 种 情况 下 ，s1 中 和 s2[j] 显 然 没 有 交集 ， 那 么 接 下 来 只 有 sl[i+1] 与 820j] 才 有 可 能 会 有 


荆 


交 人 咎 


M| 
A 
o 


5 
slTj] 
5s20] 
在 这 种 情况 下 ，s1 上 中 和 s2[j] 有 交集 (s2[j] 的 下 界 和 sl[ 的 上 界 )， 那 么 接 下 来 只 有 sl[i+1] 
与 2[j] 才 有 可 能 会 有 交集 。 
3) 
s1[i] 
5s20] 
在 这 种 情况 下 ，s1[] 和 s2[j] 有 交集 (交集 为 s2[j])， 那 么 接 下 来 具有 s1[j 与 s2[j+1] 才 有 可 
有 交集 。 


荆 


出 


slTj] 
5s20] 
在 这 种 情况 下 ， sl 和 s2[j] 有 交集 (交集 为 s1[ 计 )， 那 么 接 下 来 只 有 sl[i+t1] 与 2 中 才 有 可 

能 会 有 交集 。 
5) 
s1[i] 
s2[j] 
在 这 种 情况 下 ，s1[ 训 和 s2[j] 有 交集 (交集 为 s1[i 的 下 界 和 s2[] 的 上 界 )， 那 么 接 下 来 只 有 

sl 四 与 s2[j+1] 才 有 可 能 会 有 交集 。 
6) 
s1[i] 
5s20] 
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在 这 种 情况 下 ，sl[ 订 和 s2[j] 显 然 没 有 交集 ， 那 么 接 下 来 只 有 sl 与 s2[j+1] 才 有 可 能 会 有 
交集 


N| 


根据 以 上 分 析 给 出 实现 代码 如 下 : 
import java.util.*; 
class MySet 
{ 


private int min; 


private int max; 


public MySet(int min, int max) 


{ 
this.min=min; 
this.max=max:; 
} 
public int getMin() 
{ 
return min; 
} 
public void setMin(int min) 
{ 
this.min = min; 
} 
public int getMax() 
{ 
return max; 
} 
public void setMax(int max) 
{ 
this.max = max; 
} 
} 
public class Test 
{ 
public static ArrayList<MySet> getIntersection(ArrayList<MySet> 11,ArrayList<MySet> 12) 
{ 
ArrayList<MySet> result=new ArrayList<MySet>(); 
int 二 0; 
int j=0; 
while(i<l1.size() && j<12.size()) 
{ 


MySet s1=11.get(i); 
MySet S2=12.getO); 


if(sl.getMin()<s2.getMin()) 
{ 
if(sl.getMax()<s2.getMin()) 
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{ 
t+; 
} 
else if(sl.get Max()<=s2.getMax()) 
{ 
result.add( new MySet(s2.getMin(),s1.getMax())); 
i 
} 
else 
{ 
result.add(new MySet(s2.getMin(),s2.get Max())); 
jtt; 
} 
} 
else if(sl.getMin()<=s2.getMax()) 
{ 
if( sl.getMax()<=s2.getMax()) 
{ 
result.add( new MySet(sl.getMin(),s1.getMax())); 
J 
} 
else 
{ 
result.add( new MySet(sl.getMin(),s2.getMax())); 
jtt; 
} 
} 
else 
{ 
j++; 
} 


return result; 


public static void main(String[] args) 

{ 
ArrayList<MySet> ll=new ArrayList<MySet>(); 
ArrayList<MySet> 12= new ArrayList<MySet>(); 
ll.add(new MySet(4,8)); 
ll.add(new MySet(9,13)); 


12.add(new MySet(6,12)); 
ArrayList<MySet> result=getIntersection(l1,12); 
for(int 1=0;i<result.size(O;i++) 
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System.out.println("["+result.get(i).get Min()+","+result.get(i).get Max() 十 "] "); 


} 

这 个 算法 的 时 间 复 杂 度 为 Onal+n2)， 其 中 nl、n2 分 别 为 两 个 集合 的 大 小 。 

2. 答案 : 如 果 直 接 根据 题目 描述 的 字面 意思 去 求解 比较 抽象 ， 因 此 ， 可 以 首先 对 题目 进 
行 等 价 的 转换 : 如 果 选 出 包含 n 个 数 的 子 数组 ， 它 的 和 最 接近 整个 数组 和 的 一 半 ， 那 么 两 个 
子 数 组 的 和 是 最 接近 的 。 也 就 是 说 这 道 题 等 价 的 说 法 是 : 从 2n 个 数 中 选 出 n 个 数 ， 其 和 尽量 
接近 于 给 定 值 sum/2， 在 这 里 只 取 小 于 或 等 于 sum/2 的 情况 〈 当 一 个 子 数 组 和 小 于 或 等 于 
sum/2， 那 么 另外 一 个 子 数 组 和 一 定 大 于 或 等 于 sum/2)。 

本 题 可 以 采用 如 下 思路 进行 求解 : 
定义 一 个 辅助 的 二 维 数组 dp[k][s]， 用 来 表示 从 前 k 个 数 中 取 不 超过 1n 的 任意 个 数 ， 且 这 
些 数 之 和 为 s 的 取 法 是 否 存 在 。 

外 循环 : 在 前 kl 个 数 中 进行 选择 ，k1=1，2，…，2*n。 

内 循环 : 从 这 kl 个 数 中 任意 选 出 k2 个 数 ，k2=1，2，…，min(k1, n)。 

判断 ， 对 于 所 有 可 能 的 和 的 取 值 s (Cs=1，2，…，sum/2)， 判 断 包 含 k2 个 数 的 子 数 组 和 
为 s 且 包 含 A[kl] 的 情况 是 否 存在 。 

遍历 结束 后 ， 只 需要 在 dp[n][s] (s 入 sum/2 ) 中 找 出 存在 的 最 大 的 数 即 可 。 

实现 代码 如 下 : 


public class Test 


{ 
private final int MAXSUM=1000; 
private int min(int m, int n) 


{ 
returmm m>n?n:m; 
} 
public void getNearest(int[| arr) 
{ 


int n= arr.length / 2; 
int sum = 0; 
for (inti= 0;1<2*n;1++) 
sum += arr[j]; 
int s; 
boolean dp[][] = newboolean[2*n][MAXSUMI; 


dp[0][0] = true; 
for (int kl = 0; kl <2 * n; kl++) 
for (int k2 = min(kl, mn; k2 >= 1; k2--) 
for (s= 1; s <= Sum / 2; s++) 
// 判断 包含 k2 个 数 的 子 数组 和 为 s 且 包 含 arr[kl] 的 情况 是 否 存在 
if (s>= arr[kl] && dp[k2 - 1][s - arr[kl]]) 
dp[k2][s] = true; 

// 找 出 包含 n 个 元 素 的 子 数 组 的 和 最 接近 sum/2 的 什 
for (s= sum /2;s>= 1 && ldp[nl[s}; s--) 


223 


Java 程序 员 面试 笔试 真题 


System.out.println(" 两 个 字数 组 的 差 为 : "+ (sum - 2 * 8)); 


} 


public static void main(String[] arrrgs) 


{ 
int arr[] = { 1, 2, 3, 6}; 
new Test().getNearest(arr); 
} 
} 
程序 的 运行 结果 为 


两 个 字数 组 的 差 为 : 2 


当 数 组 中 有 负数 时 ，dp[k2][s] 下 标 使 用 了 s， 可 能 会 抛 出 异常 ， 因 此 ， 这 个 算法 对 数组 中 
有 异常 的 情况 处 理 得 不 是 很 好 。 为 了 解决 数组 中 有 异常 的 情况 ， 需 要 在 使 用 这 个 算法 前 ， 对 
数组 中 每 个 元 素 都 加 上 绝对 值 最 小 的 负数 。 这 样 可 以 将 数组 中 所 有 的 值 变 成 整数 ， 然 后 就 可 
以 使 用 上 面 的 方法 了 。 

3. 答案 : 本 题 考察 的 是 对 多 线程 编程 的 理解 。 

为 了 便于 理解 ， 首 先 用 随机 函数 随机 生成 10000 个 数 放 到 文件 中 ， 以 供 测试 使 用 。 一 次 
把 这 10000 条 记录 读 到 内 存 中 ， 平 均 分 配给 5 组 线程 运行 处 理 ， 因 此 ， 本 题 的 难点 是 如 何 控 
制 打 印 偶数 的 线程 和 打印 奇数 的 线程 轮流 运行 。 

本 题 通过 Java 提供 的 Condition 来 实现 线程 的 同步 。Condition 是 在 Java 1.5 中 才 出 现 的 ， 
它 用 来 替代 传统 的 Object 类 的 wait0 和 notify0 方 法 ， 以 实现 线程 间 的 协作 ， 相 比 使 用 Object 
类 的 wait0 和 notify0 方 法 ， 使 用 Condition 的 await0 和 signal0 这 种 方式 实现 线程 间 协 作 ， 更 
加 安全 和 高 效 。 其 主要 特点 如 下 : 
1) Condition 最 常用 的 方法 为 await0 和 signal0， 其 中 ，awaitO0 对 应 Object 类 的 wait0 方 
法 ，signal0 对 应 Object 类 的 notify0 方 法 。 

2) Condition 依赖 于 Lock 接口 ， 生 成 一 个 Condition 的 代码 为 lock.newCondition()。 

3) 调用 Condition 的 await0 和 signal0 方 法 必须 在 lock 保护 之 内 。 

对 于 本 题 而 言 ， 定 义 两 个 Condition (oddLock 和 evenLock)， 首 先 打印 奇数 的 线程 开始 
运行 ， 通 过 调用 evenLock.await0 来 等 待 打 印 偶数 的 线程 执行 。 接 着 打印 偶数 的 线程 开始 运行 ， 
当 输 出 10 个 偶数 或 者 没有 个 汝 输出 后 ， 调 用 eveLock.signal0 来 通知 打印 奇数 的 线程 开始 运行 ， 
然后 调用 oddLock.wait 方法 来 等 待 打印 奇数 的 线程 运行 完成 。 通 过 这 种 方法 来 控制 奇数 线程 
与 偶数 线程 的 运行 顺序 ， hi， 
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import java.io.*; 

import java.util.Random; 

import java.util.concurrent.locks.Condition; 
import java.util.concurrent.locks.Lock; 

import java.util.concurrent.locks.ReentrantLock; 


public class Test 


{ 


private static final int count=10000; 
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private static final int threadGruopCount=5; 
private static final String inputFile="testInput.txt"; 


public static void generateTestFile() throws IOException 


{ 
/用 随机 数 生成 10000 个 测试 数据 放 到 文件 中 
PrintWriter pw = new Print Writer(new File Writer(new File(inputFile)), true); 
Random random = new Random(); 
for (inti= 0; i< count; i++) 
{ 
pw.write(Math.abs(random.nextInt()) % count + ","); 
} 
pw.flush(); 
pw.close(); 
} 
public static void main(String[] args) 
{ 
try 
{ 
generateTestFile(); 
BufferedReader reader = new BufferedReader(new FileReader(inputFile)); 
String str = reader.readLine(); 
reader.close(); 
String[] strs = str.split(","); 
int index = 0; 
/为 了 简单 ， 每 个 文件 输出 数字 的 个 数 相同 
int countForEachFile=count/threadGruopCount; 
for (inti= 0; i< threadGruopCount; i++) 
{ 
int records[] = new int[countForEachFile]; 
for (intj = 0; j < countForEachFile; j++) 
{ 
records[j] = IntegerparseInt(strs[index]); 
index++; 
} 
PrintGroup group = new PrintGroup(records, 1); 
group.startPrint(); 
} 
} 
catch (Exception e) 
{ 
e.printStackTrace(); 
} 
} 
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class PrintGroup { 
/这 个 线程 组 输出 数字 的 个 数 
private static volatile int count = 0; 


private Lock lock = new ReentrantLock(); 

private Condition oddLock = lock.newCondition(); 

private Condition evenLock = lock.newCondition(); 
/这 个 线程 组 需要 输出 的 数字 数组 

private int Tecords[]; 

/这 个 线程 组 需要 把 数字 输出 到 同一 个 文件 ， 因 此 ， 共 享 一 个 writer 
/由 于 任意 时 刻 只 会 有 一 个 线程 写 文件 ， 因 此 ， 不 需要 同步 
private PrintWriter writer; 

/记录 输出 奇数 所 在 的 数组 下 标 

private volatile int oddIndex = 0; 

/记录 输出 偶数 所 在 的 数组 下 标 

private volatile int evenIndex = 0; 

/输出 奇数 的 线程 

private OddPrintThread oddPrintThread; 

/输出 偶数 的 线程 

private EvenPrintThread evenPrintThread; 

private volatile boolean first=true; 


private int[] result=new int[2000]; 


private int index=0; 


public PrintGroup(int[] records, int id) throws Exception { 

this.records = records; 

this.writer = new PrintWriter(new File Writer(new File("output" + id + ".txt")), true); 
} 
public void startPrint() { 

oddPrintThread = new OddPrintThread(); 

evenPrintThread = new EvenPrintThread(); 

oddPrintThread.start(); 

evenPrintThread .start(); 


} 
private class OddPrintThread extends Thread 
{ 
(QOverride 
public void run() 
{ 
while (true) 
{ 
try 
{ 
lock.lock(); 
/第 一 次 运行 时 ， 需 要 等 待 打印 偶数 的 线程 先 执行 
if(first) 
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{ 
first=false; 
evenLock.await(); 
} 
for (inti= 0;1< 10;) 
{ 
/数组 中 的 偶数 和 奇数 都 打印 完 
if (oddIndex >= records.length&& evenIndex >= records.length) 
{ 
writer.flush(); 
writer.close(); 
return; 
} 
// 如 果 所 有 的 奇数 都 打印 完了 ， 则 不 打印 奇数 ， 让 打印 偶数 的 
// 线 程 有 运行 机 会 
if (oddIndex >= records.length ) 
{ 
break; 
} 
// 把 奇数 输出 到 文件 ， 并 计数 
if (records[oddIndex] % 2 == 1) 
{ 
计 十 ; 
writer.print(records[oddIndex] + " "); 
result[index++]=records[oddIndex| ; 
writer.flush(); 
addCount(); 
} 
oddIndex++; 
} 
/打印 完 10 个 奇数 后 ， 通 知 打印 偶数 的 线程 开始 运行 
oddLock.signal(); 
/接着 等 待 打印 偶数 的 线程 结束 
evenLock.await(); 
} 
catch(Exception e) 
{ 
e.printStackTrace(); 
} 
finally 
{ 
oddLock.signal(); 
lock.unlock(); 
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} 
private class EvenPrintThread extends Thread { 
(QOverride 
public void run() 
{ 
while (true) 
{ 
try 
{ 
/等 待 打 印 奇数 的 线程 先 运行 
while(first) 
{ 
Thread. sleep(1); 
} 
lock.lock(); 
for (int1i= 0; i< 10;) 
{ 
if (oddIndex >= records.length&& evenIndex >= records.length) 
{ 
String s=""; 
for(int k=0;k<2000;k++) 
{ 
s+=(result[k]+" "); 
} 
writer.flush(); 
return; 
} 
if (evenIndex >= records.length ) 
{ 
break; 
} 
if (records[evenIndex| % 2 == 0) 
{ 
1 十; 
writer.print(records[evenIndex| + " "); 
result[index++]=records[evenIndex] ; 
writer.flush(); 
addCount(); 
} 
evenIndex+ 十 ; 
} 
evenLock.signal(); 
oddLock.await(); 
} 
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catch(Exception e) 
{ 
e.printStackTrace(); 
} 
finally 
{ 
evenLock.signal(); 
lock.unlock(); 
} 
} 
} 
} 
private synchronized static void addCount() 
{ 
countt+t; 
if (count % 1000 == 0) 
{ 
System.out.println(" 已 完成 : "+ count); 
if (count == 10000) 
{ 
System.out.println("Done"); 
} 
} 
} 
} 
程序 的 运行 结果 为 
已 完成 : 1000 
己 完成 : 2000 
已 完成 : 3000 
己 完 成 : 4000 
已 完成 : 5000 
已 完成 : 6000 
已 完成 : 7000 
已 完成 : 8000 
已 完成 : 9000 
已 完成 : 10000 
Done 


ua 县 入 叶 知 名 电子 商务 公司 软件 工程 师 笔 试题 
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分 析 : 本 题 考 察 的 是 Java 字符 串 的 知识 。 
在 Java 语言 中 ， 所 有 的 字符 都 采用 Unicode 编码 ， 用 两 个 字 节 来 编码 一 个 字符 ， 即 每 个 
Unicode 码 占用 16bit。 所 以 ， 选 项 B 正确 。 

所 以 ， 本 题 的 答案 为 了 B。 

2. 答案 : B。 

分 析 : 本 题 考 察 的 是 String 类 的 知识 。 

对 于 选项 A，Java 允许 String 类 进行 + 操作 ， 虽 然 String 是 不 变 类 ， 但 语句 st=“world” 
会 生成 一 个 新 的 字符 串 对 象 ， 其 内 容 为 “hello worldworld”， 因 此 ， 选 项 A 正确 。 

对 于 选项 B, 在 Java 语言 中 ，String 是 一 个 类 ，s 是 一 个 字符 串 对 象 ， 而 不 是 数组 ， 因 此 ， 
没有 提供 类 似 于 数组 根据 索引 随机 访问 的 功能 ， 因 此 ， 选 项 B 错误 。 

对 于 选项 C，String 类 提供 了 length(0 方 法 来 计算 字符 串 的 长 度 ， 因 此 ， 选 项 C 正确 。 

对 于 选项 D，String 类 提供 了 toLowerCase(0 方 法 ， 该 方法 用 来 将 字符 串 中 所 有 字符 转换 
为 小 写字 母 ， 因 此 ， 选 项 DD 正确 。 

所 以 ， 本 题 的 答案 为 了 B。 

3. 答案 : B。 

分 析 : 本 题 考 察 的 是 继承 知识 。 

对 于 选项 A， 在 Java 语言 中 ， 可 以 把 子 类 的 对 象 赋值 给 父 类 的 引用 变量 ， 但 是 不 可 以 把 
父 类 的 对 象 赋值 给 子 类 的 引用 ，Object 是 所 有 类 的 父 类 ， 因此， 也 是 ArrayList 的 父 类 ， 所 以 ， 
这 种 写法 是 不 合法 的 ， 如 果 换 成 语句 Object o= new ArrayList0 就 合法 了 。 所 以 ， 选 项 A 错误 。 

对 于 选项 B，ArrayList 实现 了 List 接口 。 所 以 ， 选 项 B 正确 。 

对 于 选项 C 与 选项 D， 由 于 List 是 接口 ， 因 此 ， 不 能 被 实例 化 。 所 以 ， 选 项 C 与 选项 D 
萌 误 。 

所 以 ， 本 题 的 答案 为 了 B。 

4. 答案 : A。 

分 析 : 本 题 考 察 的 是 对 Java 特性 的 理解 。 
继承 指 的 是 从 已 有 的 类 中 派生 出 新 的 类 ， 新 的 类 能 吸收 已 有 类 的 数据 属性 和 行为 ， 并 能 
扩展 新 的 能 力 。 在 Java 语言 中 ， 继 承 是 使 用 已 存在 的 类 的 定义 作为 基础 建立 新 类 的 技术 ， 新 
类 的 定义 可 以 增加 新 的 数据 或 新 的 功能 ， 也 可 以 使 用 父 类 的 功能 ， 但 不 能 选择 性 地 继承 父 类 。 
类 只 允许 单 继承 ， 但 是 为 了 实现 类 似 于 C++ 语言 中 多 继承 的 特性 ，Java 语言 引入 了 接口 的 概 
念 。 昌 然 Java 语言 上 只 允许 继承 一 个 类 ， 但 是 却 可 以 同时 实现 多 个 接口 ， 因 此 ， 也 就 间接 地 实 
现 了 多 继承 。 

从 以 上 分 析 可 知 ， 选 项 A 正确 ， 选 项 B 和 选项 DD 错误 。 

对 于 选项 C， 一 个 类 只 能 继承 一 个 类 ， 在 继承 的 同时 ， 还 可 以 实现 多 个 接口 。 因 此 ， 选 
项 C 错误 。 

所 以 ， 本 题 的 答案 为 A。 

5. 答案 : B。 

分 析 : 本 题 考 察 的 是 对 序列 化 的 理解 。 

在 分 布 式 环境 下 ， 当 进行 远程 通信 时 ， 无 论 是 何 种 类 型 的 数据 ， 都 会 以 二 进 制 序列 的 形 
式 在 网 络 上 传送 。 序 列 化 是 一 种 将 对 象 转换 成 字 节 序列 的 过 程 ， 用 于 解决 在 对 对 象 流 进行 读 
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写 操作 时 所 引发 的 问题 。 序 列 化 可 以 将 对 象 的 状态 写 在 流 里 进行 网 络 传输 ， 或 者 保存 到 文件 、 
数据 库 等 系统 里 ， 并 在 需要 的 时 候 把 该 流 读 取出 来 重新 构造 成 一 个 相同 的 对 象 。 

如 何 实现 序列 化 呢 ? 其 实 ， 所 有 要 实现 序列 化 的 类 都 必须 实现 Serializable 接口 ， 
Serializable 接口 位 于 java.lang 包 中 ， 里 面 没 有 包含 任何 方法 。 使 用 一 个 输出 流 ( 例 如 
FileOutputStream〉 来 构造 一 个 ObjectOutputStream 对象 流 ) 对 象 ， 紧 接着 ， 使 用 该 对 象 的 
writeObject (Object obj ) 方法 就 可 以 将 obj 对 象 写 出 《〈 即 保存 其 状态 )， 要 恢复 的 时 候 可 以 使 
用 其 对 应 的 输入 流 。 
具体 而 言 ， 序 列 化 有 如 下 几 个 特点 : 

1) 如 果 一 个 类 能 被 序列 化 ， 那 么 它 的 子 类 也 能 够 被 序列 化 。 

2) 由 于 static( 静 态 ) 代表 类 的 成 员 ，transient 〈Java 语言 关键 字 ， 如 果 用 transient 声明 
一 个 实例 变量 ， 当 对 象 存储 时 ， 它 的 值 不 需要 维持 ) 代表 对 象 的 临时 数据 ， 因 此 ， 被 声明 为 
这 两 种 类 型 的 数据 成 员 是 不 能 够 被 序列 化 的 。 

3 ) 子 类 实现 了 Serializable 接口 ， 父 类 没有 ， 父 类 中 的 属性 不 能 序列 化 ， 但 是 子 类 
性 仍 能 正确 序列 化 。 

通过 以 上 分 析 可 知 ， 只 有 选项 B 是 正确 的 。 

所 以 ， 本 题 的 答案 为 B。 

6. 答案 : C。 

分 析 : 本 题 考 察 的 是 对 Collection 的 理解 。 

java.util.Collection 是 一 个 集合 接口 ， 它 提供 了 对 集合 对 象 进行 基 本 操作 的 通用 接口 方法 。 
Collection 接口 在 Java 类 库 中 有 很 多 具体 的 实现 。 具 体 而 言 ，Collection 主要 方法 见 表 10。 


TH 


的 属 


表 10 Collection 主要 方法 


方 ” 法 描 述 
add(E e) 把 对 象 e 添加 到 容器 中 
addAll(Collection<? extends E> c¢) 把 c 中 的 所 有 对 象 添 加 到 容器 中 
clear() 清空 容器 
contains(Object 0) 如 果 容 器 中 有 对 象 o， 那 么 返回 tue， 否 则 ， 返 回 false 
containsAll(Collection<?> ¢) 如 果 容器 中 包含 c 中 所 有 的 对 象 ， 那 么 返回 true， 否 则 ， 返 回 false 
equals(Object o) 判断 对 象 o 是 否 和 容器 相等 
hashCode() 返回 容器 的 哈 希 值 
isEmpty() 如 果 容 器 为 空 ， 返 回 true 
0 返回 这 个 容器 的 近代 器 
remove(Object o) 从 列表 中 删除 对 象 
removeAll(Collection<?> c) 从 列表 中 删除 那些 在 c 中 存在 的 对 象 
retainAll(Collection<?> ¢) 列表 中 移 除 未 包含 在 指定 collection 中 的 所 有 元 素 
size() 返回 容器 中 元 素 的 个 数 
toArray() 返回 一 个 数组 ， 数 组 中 包含 容器 中 所 有 的 元 素 
toArray(T[] a) 与 方法 toArray 类 似 ， 不 同 之 处 为 返回 数组 的 类 型 与 参数 指定 的 类 型 相同 


所 以 ， 本 题 的 答案 为 C。 
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7. 答案 : A。 

分 析 : 本 题 考察 的 是 对 引用 的 理 角 

在 Java 语言 中 ， 有 8 种 基本 数据 类 型 ， 分 别 为 byte、short、int、long、float、double 和 
boolean， 这 8 种 基本 类 型 在 使 用 时 都 是 值 传递 ， 除 此 之 外 都 是 引用 传递 。 对 于 本 题 而 

整 型 变量 a 和 整 型 变量 b 都 是 基本 数据 类 型 ， 因 此 ，a==b 表达 的 意思 是 判断 a 和 ob 的 值 


-人 


o 


字符 


相等 ， 由 于 a 与 b 的 值 都 为 5， 所 以 ， 比 较 的 结果 为 true。 
在 定义 String s1="Hello" 时 ， 会 把 "Hello" 字 符 串 存 储 到 常量 区 里 ， 栈 中 的 变量 s1 是 这 个 
串 的 引用 (为 了 便于 理解 ， 可 以 理解 为 sl 的 值 为 这 个 字符 串 常量 的 地 址 )， 同 理 ， 在 定 


义 52 时 ， 发现 常量 区 已 经 有 这 个 字符 串 存在 ， 因 此 ，s2 也 会 引用 这 个 字符 串 (s2 的 值 也 是 这 


ex 


个 字 


正确 


常 出 


可 以 


符 串 常量 的 地 址 )， 即 sl 的 值 与 s2 的 值 相同 ，s2==sl 的 值 为 tue。 所 以 ， 选 项 A 正确 。 
如 果 将 题目 改 成 如 下 形式 : 

String sl=new String(Hello”); 

String s2=new String(CHello”); 

虽然 s1 与 82 的 内 容 相同 ， 但 两 次 new 操作 会 在 堆 上 分 配 两 个 字符 串 ， 它 们 的 地 址 也 不 
因此 ，s1 与 2 的 值 也 就 不 同 ， 在 这 种 情况 下 ，s1 一 s2 的 结果 就 为 false。 

所 以 ， 本 题 的 答案 为 A。 


参见 真题 4 中 多 项 选择 题 6。 


参见 真题 2 中 单项 选择 题 1。 

10. 答案 : B、C。 

分 析 : 本 题 考察 的 是 对 异常 处 理 的 理解 。 

对 于 选项 A 与 选项 B， 不 管 有 无 异常 ，finally 块 都 会 执行 。 所 以 ， 选 项 A 错误 ， 选 项 B 


对 于 选项 C，catch 代码 块 的 作用 是 在 异常 出 现时 对 异常 情况 进行 处 理 ， 因 此 ， 只 有 当 异 
现 的 时 候 ， 才 会 执行 catch 块 的 代码 。 所 以 ， 选 项 C 正确 。 
所 以 ， 本 题 的 答案 为 B、C。 

二 、 问 答题 

1. 答案 : ArrayList、Vector 和 LinkedList 类 均 在 java.util 包 中 ， 都 是 可 伸缩 的 数组 ， 即 
动态 改变 长 度 的 数组 。 

ArrayList 和 Vector 都 是 基于 存储 元 素 的 Object[] array 来 实现 的 ,它们 会 在 内 存 中 开辟 一 


块 连续 的 空间 来 存储 ， 由 于 数据 存储 是 连续 的 ， 因 此 ， 它 们 支持 用 序号 〈 索 引 、 下 标 ) 来访 
问 元 素 ， 同 时 ， 索 引 数 据 的 速度 比较 快 。 但 是 在 插入 元 素 时 ， 需 要 移动 容器 中 的 元 素 ， 所 以 ， 


对 数据 的 插入 操作 执行 速度 比较 慢 。ArrayList 和 Vector 都 有 一 个 初始 化 的 容量 的 大 小 ， 当 里 
面 存储 的 元 素 超 过 这 个 大 小 的 时 候 ， 就 需要 动态 地 扩充 它们 的 存储 空间 。 为 了 提高 程序 的 效 


率 ,每 次 扩充 容量 时 不 是 简单 地 扩充 一 个 存储 单元 ， 而 是 一 次 就 会 增加 多 个 存储 单元 。Vector 
默认 扩充 为 原来 的 两 售 ( 每 次 扩充 空间 的 大 小 是 可 以 设置 的 )， 而 ArrayList 默认 扩充 为 原来 


的 1. 


5 倍 ( 没 有 提供 方法 来 设置 空间 扩充 的 方法 )。 
ArrayList 与 Vector 最 大 的 区 别 就 是 synchronization (同步 ) 的 使 用 ， 没 有 一 个 ArrayList 
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的 方法 是 同步 的 , 而 Vector 的 绝 大 多 数 的 方法 (例如 add、insert、remove、 set、equals 及 hashcode 
等 ) 都 是 直接 或 者 间接 同步 的 ， 所 以 ，Vector 是 线程 安全 的 ，ArrayList 不 是 线程 安全 的 。 正 
是 由 于 Vector 提供 了 线程 安全 的 机 制 ， 使 其 性 能 上 也 要 上 略 撑 于 ArrayList。 

LinkedList 是 采用 双向 列表 来 实现 的 ， 对 数据 的 索引 需要 从 列表 头 开始 遍历 ， 因 此 ， 随 机 
访问 的 效率 比较 低 ， 但 是 插入 元 素 时 ， 不 需要 对 数据 进行 移动 ， 因 此 ， 插 入 效率 较 高 。 同 时 ， 
LinkedList 不 是 线程 安全 的 。 

那么 ， 在 实际 使 用 时 ， 如 何 从 这 几 种 容器 中 选择 合适 的 呢 ? 当 对 数据 的 主要 操作 为 索引 
或 只 在 集合 的 末端 增加 、 删 除 元 素 时 ， 使 用 ArrayList 或 Vector 效率 比较 高 。 当 对 数据 的 操作 
主要 为 指定 位 置 的 插入 或 删除 操作 时 ， 使 用 LinkedList 效率 比较 高 。 当 在 多 线程 中 使 用 容器 
〈 即 多 个 线程 会 同时 访问 该 容器 ) 时 ， 选 用 Vector 较为 安全 。 

2. 在 Java 语言 中 ，GC (Garbage _ Collection， 垃 圾 回收 ) 是 一 个 非常 重要 的 概念 ， 其 主 
要 作用 是 回收 程序 中 不 再 使 用 的 内 存 。 在 使 用 C/C++ 语言 进行 程序 开发 时 ， 开 发 人 员 必 须 非 
常 仔细 地 管理 好 内 存 的 分 配 与 释放 ， 如 果 态 记 或 者 错误 地 释放 内 存 往往 会 导致 程序 运行 不 正 
确 甚至 是 程序 的 骨 尝 。 为 了 减轻 开发 人 员 的 工作 ， 同 时 增加 系统 的 安全 性 与 稳定 性 ，Java 语 
言 提供 了 垃圾 回收 器 来 自动 检测 对 象 的 作用 域 , 实现 自动 地 把 不 再 被 使 用 的 存储 空间 释放 掉 。 
具体 而 言 ， 垃 圾 回收 器 要 负责 完成 3 项 任务 : 分 配 内 存 、 确 保 被 引用 对 象 的 内 存 不 被 错误 地 
回收 以 及 回收 不 再 被 引用 的 对 象 的 内 存 空间 。 

垃圾 回收 器 的 存在 ， 一 方面 把 开发 人 员 从 释放 内 存 的 复杂 的 工作 中 解脱 出 来 ， 提 高 了 开 
发 人 员 的 生产 效率 另 一 方面 ， 对 开发 人 员 屏 蔽 了 释放 内 存 的 方法 ， 可 以 避免 因为 开发 人 员 
错误 地 操作 内 存 从 而 导致 应 用 程序 的 崩 淡 ， 保 证 了 程序 的 稳定 性 。 但 是 ， 垃 圾 回收 也 带 来 了 
问题 ， 为 了 实现 垃圾 回收 ， 垃 圾 回收 器 必须 跟踪 内 存 的 使 用 情况 ， 释 放 没 用 的 对 象 ， 在 完成 
内 存 的 释放 后 ， 还 需要 处 理 堆 中 的 雄 片 ， 这 些 操作 必定 会 增加 JVM 的 负担 ， 从 而 降低 程序 的 
执行 效率 。 

对 于 对 象 而 言 ， 如 果 没 有 任何 变量 去 引用 它 ， 那 么 该 对 象 将 不 可 能 被 程序 访问 ， 因 此 ， 
可 以 认为 它 是 垃圾 信息 ， 可 以 被 回收 。 只 要 有 一 个 以 上 的 变量 引用 该 对 象 ， 该 对 象 就 不 会 被 
垃圾 回收 。 

对 于 垃圾 回收 器 来 说 ， 它 使 用 有 向 图 来 记录 和 管理 堆 内 存 中 的 所 有 对 象 ， 通 过 这 个 有 向 
图 就 可 以 识别 哪些 对 象 是 “可 达 的 ”〈《 有 引用 变量 引用 它 就 是 可 达 的 )， 哪 些 对 象 是 “不 可 达 
的 (没有 引用 变量 引用 它 就 是 不 可 达 的 )， 所 有 “不 可 达 ” 对 象 都 是 可 被 垃圾 回收 的 。 如 下 
例 所 示 : 


Tt 


= 


public class Test 


{ 

public static void main(String[] a) 

{ 
Integer il=new Integer(1); 
Integer 12=new Integer(2); 
12=11; 

//some other code 
} 
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看 句 i2=il 后 ， 内 存 的 引用 关系 图 21 所 示 。 


C1 
C0 > 


图 21 内 存 的 引用 关系 
行 垃圾 回收 操作 ， 在 遍历 上 述 有 向 图 时 ， 资 源 2 所 占 的 内 


存 是 不 可 达 的 ， 垃 圾 回收 器 就 会 认为 这 块 内 存 已 经 不 会 再 被 使 用 了 ， 因 此 ， 就 会 回收 该 块 内 


存 空 间 。 


于 垃圾 


也 就 是 说 ， 开 发 人 员 不 能 实时 地 调 月 
发 人 员 却 可 以 通过 调 


回收 器 的 存在 , Java 语言 本 身 没有 给 开发 人 员 提 供 显 式 释 放 已 分 配 内 存 的 方法 ， 
垃圾 回收 器 对 某 个 对 象 或 所 有 对 象 进行 垃圾 回收 。 但 开 
j System.gc0 方 法 来 通知 垃圾 回收 器 运行 ， 当 然 ，JVM 也 并 不 会 保证 垃 


圾 回收 器 马上 就 会 运行 。 由 于 gc 方法 的 执行 会 停止 所 有 的 响应 ， 去 检查 内 存 中 是 否 有 可 回收 
这 会 对 程序 的 正常 运行 以 及 性 能 造成 极 大 的 威胁 ， 所 以 ， 在 实际 编程 中 ， 不 推荐 频 


的 对 象 ， 


繁 使 用 gc 方法 。 


3. 答案 :可 以 进行 优化 ， 优 化 后 的 代码 为 


Object object; 
for(int 1=0;i<1000;i++) 
{ 


object = new Object(); 


System.out.println("object name is"+object); 


} 


分 析 : 题目 中 的 写法 ，object 的 作用 范围 为 for 循环 内 部 ， 每 当 执行 一 次 循环 时 ， 就 需要 


在 栈 中 分 配 一 个 存储 空间 给 object 使 用 
回收 object 占用 的 栈 空间 。 本 题 中 ， 由 
空间 ， 同 时 回收 1000 次 存储 空间 ， 

如 果 改 月 


F 销 是 非常 大 的 。 
月 上 述 写法 后 ，object 在 整个 for 循环 执行 的 过 程 中 都 是 可 见 的 。 因此， 就 不 需要 


， 这 次 循环 结束 后 ，object 的 作用 域 就 结束 了 ， 就 需要 
于 循环 次 数 为 1000 次 ， 所 以 ， 需 要 分 配 1000 次 存储 


不 断 地 在 栈 中 给 object 申请 与 释放 空间 了 ， 显 然 ， 此 种 方法 具有 更 高 的 效率 。 

4. 多 态 是 面向 对 象 程序 设计 中 代码 重用 的 一 个 重要 机 制 ， 它 表示 当 同 一 个 操作 作用 在 不 
同 的 对 象 时 ， 会 有 不 同 的 语义 ， 从 而 会 产生 不 同 的 结果 。 比 如 : 同样 是 “+” 操 作 ，3+4 用 来 
实现 整数 相 加 ， 而 “3”+“4?” 却 实现 了 字符 串 的 连接 。 

在 Java 语言 中 ， 多 态 主要 有 以 下 两 种 表现 方式 : 


(1 ) 重 载 (Overload ) 


就 可 以 


态 性 
4DAN 9 


重 载 是 指 同一 个 类 中 有 


(2) 覆盖 〈Override) 
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多 个 同名 的 方法 ， 但 这 些 方法 有 着 不 同 的 参数 ， 因 此 ， 在 编译 时 
角 定 到 底 调用 哪个 方法 ， 它 是 一 种 编译 时 多 态 。 重 载 可 以 被 看 作 是 一 个 类 中 的 方法 多 
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子 类 可 以 履 盖 父 类 的 方法 ， 因 此 ， 同 样 的 方法 会 在 父 类 与 子 类 中 有 着 不 同 的 表现 形式 。 
在 Java 语言 中 ， 基 类 的 引用 变量 不 仅 可 以 指向 基 类 的 实例 对 象 ， 也 可 以 指向 其 子 类 的 实例 对 
象 。 同 样 ， 接 口 的 引用 变量 也 可 以 指向 其 实现 类 的 实例 对 象 。 而 程序 调用 的 方法 在 运行 期 才 
动态 绑 定 〈 绑 定 指 的 是 将 一 个 方法 调用 和 一 个 方法 主体 连接 到 一 起 )， 就 是 引用 变量 所 指向 的 
具体 实例 对 象 的 方法 ， 也 就 是 内 存 里 正在 运行 的 那个 对 象 的 方法 ， 而 不 是 引用 变量 的 类 型 中 
定义 的 方法 。 通 过 这 种 动态 绑 定 的 方法 实现 了 多 态 。 由 于 只 有 在 运行 时 才能 确定 调用 哪个 方 
法 ， 因 此 ， 通 过 方法 覆盖 实现 的 多 态 也 可 以 被 称 为 运行 时 多 态 。 如 下 例 所 示 : 


class Base 
public Base() 
{ 
gO); 
} 
public void f() 
{ 
System.out.println("Base f()"); 
} 
public void g() 
{ 
System.out.println("Base gO"); 


} 


} 


class Derived extends Base 
{ 
public void f() 
{ 
System.out.println("Derived f()"); 
} 
public void g() 
{ 
System.out.println("Derived gO)"); 


} 


} 


public class Test 
{ 
public static void main(String[] args) 
{ 
Base b=new Derived(); 
b.f0; 
b.g0; 


} 


程序 的 输出 结果 为 
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Derived g() 
Derived f() 
Derived g() 


上 例 中 ， 由 于 子 类 Derived 的 人 0 方法 和 gO 方法 与 父 类 Base 的 方法 同名 ， 因 此 ，Derived 
的 方法 会 覆盖 Base 的 方法 ,在 执行 Base b =new Derived0 语 句 时 , 会 调用 Base 类 的 构造 函数 ， 
而 在 Base 的 构造 函数 中 , 执行 了 g0 方 法 , 由 于 Java 语言 的 多 态 特性 , 此 时 会 调用 子 类 Derived 
的 g0 方 法 ， 而 非 父 类 Base 的 gO 方法， 因此， 会 输出 Derived g0。 由 于 实际 创建 的 是 Derived 
类 的 对 象 ， 后 面 的 方法 调用 都 会 调用 子 类 Derived 的 方法 。 

此 外 ， 只 有 类 中 的 方法 才 有 多 态 的 概念 ， 类 中 成 员 变 量 没有 多 态 的 概念 。 如 下 例 所 示 : 


class Base 


{ 

public int i=1; 
1 
了 


class Derived extends Base 


public int 1=2; 
} 
public class Test 
{ 
public static void main(String[] args) 
{ 
Base b=new Derived(); 
System.out.printin(b.1); 
} 
+ 
程序 输出 结果 为 


1 


| 此 可 见 ， 成 员 变量 是 无 法 实现 多 态 的 ， 成 员 变 量 的 值 是 取 父 类 还 是 子 类 并 不 取决 于 创 
建 对 象 的 类 型 ， 而 是 取决 于 定义 的 变量 的 类 型 ， 这 是 在 编译 期 间 确定 的 。 在 上 例 中 ， 由 于 b 
所 属 的 类 型 为 Base，b.i 指 的 是 Base 类 中 定义 的 i， 所 以 ， 程 序 输 出 结果 为 1。 


5. 答案 : 数字 签名 使 用 发 送 方 的 密 钥 对 ， 发 送 方 使 用 


己 的 私有 密 钥 进行 加 密 ， 而 接收 


方 只 需要 发 送 方 的 公开 密 钥 就 可 以 解密 ， 是 一 种 一 对 多 的 关系 ， 只 要 持 有 发 送 方 公开 密 钥 的 


人 


人 都 可 以 验证 数字 签名 的 正确 性 。 


加 密 是 一 种 以 密码 方式 发 送信 息 的 方法 ， 指 的 是 如 下 这 样 一 个 过 程 : 发送 方 利用 接收 方 


的 公 钥 对 要 发 送 的 明文 进行 加 密 ， 接 收 方 利用 自己 的 私 钥 进 行 解密 ， 其 中 公 钥 和 私 钥 是 相对 
的 ， 任 何 一 个 作为 公 钥 ， 则 另 一 个 就 为 私 钥 。 所 以 ， 加 密使 用 的 是 接收 方 的 密 钥 对 ， 这 是 一 


种 多 对 一 的 关系 ， 任 何 知道 接收 方 公开 密 钥 的 人 者 


有 接收 方 私有 密 钥 的 人 才能 对 信息 解密 。 


可 以 向 接收 方 发 送 加 密 信 息 ， 只 有 唯一 拥 


另外 ， 数 字 签 名 采用 的 是 非 对 称 密 钥 加 密 算法 ， 它 能 保证 发 送信 息 的 完整 性 、 身 份 认 证 
和 不 可 否认 性 , 而 数字 加 密 采 用 的 是 对 称 密 钥 加 密 算法 和 非 对 称 密 钥 加 密 算法 相 结 合 的 方法 。 
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6. 答案 : 网 络 上 的 两 个 程序 通过 一 个 双向 的 通信 连接 实现 数据 的 交换 ， 这 个 双向 链 路 的 
一 端 称 为 一 个 Socket。Socket 也 称 为 套 接 字 ， 可 以 用 来 实现 不 同 虚拟 机 或 不 同 计算 机 之 间 的 
通信 。 在 Java 语言 中 ，Socket 可 以 分 为 两 种 类 型 : 面向 连接 的 Socket (Transmission Control 
Protocol，TCP， 传 输 控 制 协议 ) 通信 协议 和 面向 无 连接 的 Socket (User Datagram Protocol， 
UDP， 用 户 数据 报 协议 ) 通信 协议 。 任 何 一 个 Socket 都 是 由 卫 地 址 和 端口 号 唯一 确定 的 ， 如 
22 所 示 。 


接收 线程 
发 送 线程 IP: 127.0.0.1 


端口 : 1501 


端口 : 1500 


操作 系统 操作 系统 


网 络 


图 22 ”Socket 的 连接 和 建立 


基于 TCP 协议 的 通信 过 程 如 下 : 首先 ，Server 端 Listen 〈 监 听 ) 指定 的 某 个 端口 (建议 
使 用 大 于 1024 的 端口 ) 是 否 有 连接 请 求 ， 然 后 ，Client 端 向 Server 端 发 出 Connect( 连 接 ) 
请 求 ， 紧 接着 ，Server 端 向 Client 端 发 回 Accept (接受 ) 消息 。 一 个 连接 就 建立 起 来 了 ， 会 
话 随即 产生 。Server 端 和 Client 端 都 可 以 通过 Send、Wirite 等 方法 与 对 方 通信 。 

Socket 的 生命 周期 可 以 分 为 三 个 阶段 :打开 Socket、 使 用 Socket 收发 数据 以 及 关闭 Socket。 
在 Java 语言 中 ， 可 以 使 用 ServerSocket 作为 服务 端 ，Socket 作为 客户 端 来 实现 网 络 通 信 。 

下 面 给 出 一 个 例子 ， 用 Socket 通信 写 出 客户 端 和 服务 器 端的 通信 ， 要 求 客户 发 送 数据 后 
能 够 回 显 相同 的 数据 。 

首先 ， 创 建 一 个 名 为 Serverjava 的 服务 端 程序 代码 ， 如 下 所 示 : 


import java.net.*; 
import java.io.*; 
class Server 
{ 
public static void main(String[] args) 
{ 
BufferedReader br = null; 
PrintWriter pw = null; 
ServerSocket server =null; 
try 
{ 
server = new ServerSocket(2000); 
Socket socket = server.accept(); 
/ 获取 输入 流 
br = new BufferedReader(new InputStreamReader(socket.getInputStream())); 
/ 获取 输出 流 
pw = new PrintWriter(socket.getOutputStream(), true); 
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String s = br.readLine(); // 获取 接收 的 数据 
pw.printin(s);// 发 送 相同 的 数据 给 客户 端 
} 
catch (Exception e) 
{ 
e.printStackTrace(); 
} finally 
{ 
try 
{ 
if(br!=null) br.close(); 
if(pw!=null) pw.close(); 
if(server!=null) server.close(); 
} 
catch (Exception e) { 
} 
} 


} 


然后 ， 创 建 一 个 Clientjava 的 客户 端 程序 代码 ， 如 下 所 示 : 


import java.net.*; 
import java.io.*; 
class Client 
{ 
public static void main(String[] args) 
{ 
BufferedReader br = null; 
PrintWriter pw = null; 
Socket socket = null; 
try 
{ 
socket = new Socket("localhost", 2000); 
/获取 输入 流 与 输出 流 
br= new BufferedReader(new InputStreamReader(socket.getInputStream())); 


pw = new PrintWriter(socket.getOutputStream(), true); 
/向 服务 器 发 送 数据 
pw.println("Hello"); 
String s = nmull; 
while (true) { 

s= brreadLine(); 

if (s != null) 

break; 


} 


System.out.println(s); 
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} 
catch (Exception e) 
{ 
e.printStackTrace(); 
} 
finally 
{ 
try 
{ 
if(br!=null) br.close(); 
if(pw!=null) pw.close(); 
if(socket!=null) socket.close(); 
} catch (Exception e) 
{ 
} 
} 
} 
} 


最 后 启动 服务 端 程序 ， 并 运行 客户 端 程序 ， 客 户 端 将 会 把 从 服务 器 端 转发 过 来 的 “Hello” 
打印 出 来 。 

7. 答案 : 目前 ， 对 XML 的 解析 最 主要 的 方式 有 两 种 : DOM (Document Object Model， 
文档 对 象 模型 ) 和 SAX (Simple API forXML，XML 简单 API)。 其 中 ，DOM 方式 会 根据 给 
定 的 XML 文件 在 内 存 中 创建 一 个 树 形 结构 ， 因 此 ,这 种 处 理 方法 会 占用 较 多 的 内 存 ,， 在 处 理 
大 文件 的 时 候 ， 效 率 会 急剧 下 降 。 而 且 ，DOM 必须 在 解析 文件 之 前 就 把 整个 文档 装 入 内 存 ， 
所 以 ， 该 方式 主要 适用 于 对 XML 的 随机 访问 与 频繁 地 对 XML 中 的 内 容 进行 修改 的 场合 。 而 
SAX 是 事件 驱动 型 的 XML 解析 方式 , 它 不 会 在 内 存 中 存储 XML 文件 的 内 容 , 只 是 把 每 次 对 
数据 的 请 求 看 成 是 一 个 事件 ， 通 过 遍历 文件 来 获取 用 户 所 需 的 数据 。 当 过 到 像 文 件 开头 、 文 
档 结 束 或 者 标签 开头 与 标签 结束 时 ， 它 会 触发 一 个 事件 ， 用 户 通过 在 其 回调 事件 中 写 入 处 理 
代码 来 处 理 XML 文件 。 所 以 ， 它 的 使 用 场合 一 般 为 对 XML 的 顺序 访问 、XML 文件 太 大 以 
至 于 在 内 存 中 放 不 下 等 情况 。 

下 面 分 别 给 出 它们 操作 XML 的 示例 。 首 先 创 建 一 个 test.xml， 内 容 如 下 : 


<?xml version="1.0" encoding="UTF-8"?> 

<people> 

<p> 
<name>namel</name> 
<age>23</age> 

</p> 

<p> 
<name>name2</name> 
<age>24</age> 

</p> 


</people> 
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采用 DOM 的 方式 进行 解析 ， 示 例 代码 如 下 : 


import java.io.File; 
import org.w3c.dom.*; 
import javax.xml.parsers.*; 


public class Test 


{ 
public static void main(String arge[]) 
{ 
try 
{ 


File f=new File("test.xml ); 


DocumentBuilder builder=factory.newDocumentBuilder(); 
Document doc = builder.parse(f); 

NodeList nl = doc.getElementsByTagName("p"); 

for (int 1=0;i<nl.getLength();i++) 

{ 


getFirstChild().getNode Value()); 


下 人 


getFirstChild().getNodeValue()); 


} 
}catch(Exception e) 
{ 

System.out.printin(e.getMessage()); 
} 


} 


DocumentBuilderFactory factory=DocumentBuilderFactory.newInstance(); 


System.out.print(" 姓名:" + doc.getElementsByTagName("name").item(i). 


System.out.printmn(" 年 龄 :" + doc.getElementsByTagName("age").item(i). 


程序 运行 结果 如 下 所 示 : 


姓名 :namel 年 龄 :23 
姓名 :name2 年 龄 :24 


采用 SAX 的 方式 进行 解析 ， 示 例 代码 如 下 : 


import java.io.File; 

import javax.xml.parsers.SAXParser; 

import javax.xml.parsers.SAXParserFactory; 
import org.xml.sax.Attributes; 

import org.xml.sax.SAXException; 

import org.xml.sax.helpers. DefaultHandler; 
public class Test extends DefaultHandler 

1 


public void characters(char[] ch, int start, int length) throws SAXException 


{ 


System.out.print(new String(ch, start, length)); 


super.characters(ch, start, length); 
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} 
public void endDocument( throws SAXException 
{ 
super.endDocument(); 
} 
public void endElement(String url String localName, String qName)throws SAXException 
{ 
System.out.print("</"+qName+">"); 
super.endElement(url, localName, qName); 
} 
public void startDocument() throws SAXException 
{ 
System.out.println("<2xml version=\"1.0\" encoding=\"UTF-8\"?>"); 
super.startDocument(); 
} 
public void startElement(String uri,String localName,String qName,Attributes attrs) throws 
SAXException 
{ 
System.out.print("<"+qName); 
if (attrs != null) 
{ 
for (inti= 0; i< attrs.getLength(); i++) 
{ 
System.out.print(" " + attrs.get QName(i) + "=\"" + attrs.getValue(i) + \""); 
} 
} 
System.out.print(">"); 
super.startElement(uri, localName, qName, attrs); 
} 
public static void main(String[] args) throws Exception 
{ 
SAXParserFactory factory = SAXParserFactory.newInstance(); 
SAXParser parser = factory.newSAXParser(); 
File f= new File("test.xml"); 
Test dh = new Test(); 
parser.parse(f, dh); 
} 


} 


运行 结果 如 下 : 


<?xml version="1.0" encoding="UTF-8"?> 
<people> 
<p> 
<name>namel</name> 
<age>23</age> 
</p> 
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<p> 
<name>name2</name> 
<age>24</age> 
</p> 
</people> 
8. 事务 是 数据 库 中 一 个 单独 的 执行 单元 (unit)， 它 通常 由 高 级 数据 库 操作 语言 (例如 


SQL) 或 编程 语言 (例如 C++、Java 等 ) 编写 的 
PF 更 改 的 数据 便 会 提交 ， 不 


数据 成 功 时 
无 效 。 


， 在 事务 


户 程序 的 执行 所 引起 。 当 在 数据 库 中 更 改 


例如 网 上 购物 ， 其 交易 过 程 至 少 包 括 以 下 几 个 步骤 的 操作 : 


1) 更 


2) 保存 客户 付款 信息 。 


3) 生成 订单 并 且 


保存 到 数据 库 


新 客户 所 购 商 品 的 库存 信息 。 


bt 


| 
o 


4) 更 新 用 户 相关 信息 ， 例 如 购物 数量 等 。 


在 正常 的 ' 


恩 也 成 功 地 更 新 。 但 是 ， 如 果 在 执行 也 
过 程 中 任何 一 个 环节 


足 等， 都 将 导 


个 


整个 交易 过 程 失 败 。 而 一 旦 交易 失败 ， 数 据 库 ! 
的 状态 不 变 ， 例 如 最 后 一 步 更 新 用 户 信息 时 失败 而 导致 交易 失败 ， 那 么 业 
易 不 影响 数据 库 的 状态 ， 即 原 有 的 库存 信息 没有 被 更 新 、 用 户 也 没有 付款 、 
则 ， 数 据 库 的 信息 将 会 不 一 致 ， 或 者 出 现 更 为 严重 的 不 可 预测 的 后 果 。 数 据 库 事务 正 


下 改变。 和 否则， 事务 就 取消 或 者 


回 滚 ， 更 改 


青 况 下 ， 这 些 操作 都 将 顺利 进行 ， 最 终 交 易 成 功 ， 与 交易 相关 的 所 有 数据 库 信 


中 途 遇 到 突然 掉 电 或 者 其 他 意外 情况 ， 导 致 这 
了 差错 ， 例 如 在 更 新 商品 库存 信息 时 发 生 异 常 、 


交 
成 ， 
且 . 
RE 


事务 必须 满足 


和 持久 性 (qdurability)， 即 ACID 四 种 


(1) 原子 性 


用 来 保证 这 种 情况 下 交易 的 3 
四 个 属性 ， 即 原子 性 


F 稳 性 和 可 预测 性 的 技术 。 
Catomicity)、 一 致 性 (consistency)、 隔 离 性 (isolation) 
四 种 特性 进行 介绍 。 


属性 。 以 下 将 分 别 对 这 


系列 


顾客 银行 账户 余额 不 
所 有 信息 都 必须 保持 交易 前 


, 须 保证 这 笔 失败 的 
订单 也 没有 生 


事务 是 一 个 不 可 分 割 的 整体 ， 为 了 保证 事务 的 总 体 目标 ， 事 务必 须 具 有 原子 性 ， 即 当 数 
据 修改 时 ， 要 么 全 都 执行 ， 要 么 全 都 不 执行 ， 即 不 允许 事务 部 分 地 完成 ， 避 免 了 只 执行 这 些 
操作 的 一 部 分 而 带 来 的 错误 。 


(2) 一 致 性 


一 个 事务 在 执行 之 前 和 执行 之 后 ， 数 据 库 数 据 必 须 保 持 一 致 性 状态 。 数 据 库 的 一 致 性 状 


态 应 该 满足 模式 锁 # 


了 维护 所 有 数据 的 完 


库 的 一 致 性 状态 由 


额 之 和 应 保持 不 变 。 


旨 定 的 约束 ， 那 么 在 完整 执行 该 事务 后 ， 数 据 库 仍然 处 于 一 致 性 状态 。 为 


整 性 ， 在 关系 型 数据 库 中 ， 所 有 的 规则 必须 应 用 到 事务 的 修改 上 。 数 据 


j 户 来 负责 ， 


1 于 并 发 操 


作 带 来 的 数据 不 一 致 性 通常 包括 以 


改 、 读 “及 ”数据 、 不 可 重复 读 和 产生 幽灵 数据 。 


(3) 隔离 性 


隔离 性 也 被 称 为 独立 性 ， 当 两 个 或 多 个 事务 并 发 执行 时 ， 为 了 保 记 
个 事务 内 部 的 操作 隔离 起 来 ， 不 被 其 他 的 正在 进行 的 事务 看 到 。 例 如 对 
T2， 对 Tl 而 言 ，T2 要 么 在 Tl 开始 之 前 已 经 结束 ， 要 么 在 Tl 完成 之 后 再 
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I 并 发 控制 机 制 实现 ， 例 如 银行 转账 ， 转 账 前 后 两 个 账户 金 


下 几 利 


和 类型: 丢失 数据 修 


FE 数据 的 安全 性 ， 将 一 
任何 一 对 事务 T1 和 


开始 执行 。 数 据 库 


真题 详解 篇 


有 四 种 类 型 的 事务 隔离 级 别 : 不 提交 的 读 、 提 交 的 读 、 可 重复 的 读 和 串 行 化 。 因 为 隔离 性 使 
得 每 个 事务 的 更 新 在 它 被 提交 之 前 ， 对 其 他 事务 都 是 不 可 见 的 ， 所 以 ， 实 施 隔离 性 是 解决 临 
时 更 新 与 消除 级 联 回 滚 问题 的 一 种 方式 。 

(4) 持久 性 

持久 性 也 被 称 为 永久 性 ， 事 务 完成 以 后 ，DBMS 保证 它 对 数据 库 中 的 数据 的 修改 是 永久 
性 的 ， 当 系统 或 介质 发 生 故 障 时 ， 该 修改 也 永久 保持 。 持 和 久 性 一 般 通 过 数据 库 备 份 与 恢复 来 
保证 。 

严格 而 言 ， 数 据 库 事务 属性 都 是 由 数据 库 管 理 系统 来 进行 保证 的 ， 在 整个 应 用 程序 的 运 
行 过 程 中 ， 应 用 程序 无 须 考 虑 数据 库 的 ACID 实现 。 
一 般 情 况 下 ， 通 过 执行 COMMIT 〈 提 交 ) 或 ROLLBACK〔 回 深 ) 语句 来 终止 事务 ， 当 
执行 COMMIT 语句 时 ， 自 从 事务 启动 以 来 对 数据 库 所 做 的 一 切 更 改 就 成 为 永久 性 的 ， 即 被 写 
入 到 磁盘 ， 而 当 执 行 ROLLBACK 语句 时 ， 自 从 事务 启动 以 来 对 数据 库 所 做 的 一 切 更 改 都 会 
被 撤销 ， 并 且 数 据 库 中 内 容 返 回 到 事务 开始 之 前 所 处 的 状态 。 无 论 什 么 情况 ， 在 事务 完成 时 ， 
都 能 保证 回 到 一 致 状态 。 
9. 答案 : 在 Java 语言 中 ， 可 以 使 用 stop 方法 与 suspend 方法 来 终止 线程 的 执行 。 当 使 
用 Thread.stop() 方 法 来 终止 线程 时 ， 它 会 释放 已 经 锁定 的 所 有 的 监视 资源 。 如 果 当 前 任何 一 
个 受 这 些 监视 资源 保护 的 对 象 处 于 一 个 不 一 致 的 状态 ,其 他 的 线程 将 会 看 到 这 个 不 一 致 的 状 
态 ， 这 可 能 会 导致 程序 执行 的 不 确定 性 ， 并 且 这 种 问题 很 难 被 定位 。suspend 方法 的 使 用 容 
易 引 起 死 锁 。 由 于 调用 suspend 方法 不 会 释放 锁 , 这 就 会 导致 一 个 问题 :如 果 使 用 一 个 suspend 
挂 起 一 个 有 锁 的 线程 ， 那 么 在 锁 恢 复 之 前 将 不 会 被 释放 。 如 果 调 用 suspend 方法 的 线程 试图 
取得 相同 的 锁 ， 程 序 就 会 发 生死 锁 。 例 如 ， 线 程 B 已 经 获取 到 了 互 斥资 源 M 的 锁 ， 此 时 线 
程 A 通过 suspend 方法 挂 起 线程 A 的 执行 ， 接 着 线程 B 也 去 访问 互 斥 资源 M， 这 时 候 就 造 
成 了 死 锁 。 鉴 于 以 上 两 种 方法 的 不 安全 性 ，Java 语言 已 经 不 建议 使 用 以 上 两 种 方法 来 终止 
线程 了 。 

那么 ,如何 才能 终止 线程 呢 ? 一 般 建 议 采 用 的 方法 是 让 线程 自行 结束 , 进入 Dead (死亡 ) 
状态 。 一 个 线程 要 进入 Dead 状态 ， 就 是 执行 完 run 方法 ， 也 就 是 说 ， 如 果 想 要 停止 一 个 线程 
的 执行 ， 就 要 提供 某 种 方式 让 线程 能 够 自动 结束 run 方法 的 执行 。 在 实现 的 时 候 ， 可 以 通过 
设置 一 个 flag 标志 来 控制 循环 是 否 执 行 ， 通 过 这 种 方法 来 让 线程 离开 run 方法 ， 从 而 终止 线 
程 。 下 例 给 出 了 结束 线程 的 方法 。 


public class MyThread implements Runnable 
{ 
private volatile Boolean flag; 
public void stop() 
{ 
flag = false; 
} 
public void run() 
{ 
while(flag) 
;//do something 
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} 
上 例 中 ， 通 过 调用 MyThread 的 stop 方法 虽然 能 够 终止 线程 ， 但 同样 也 存在 问题 : 当 线 
程 处 于 非 运行 状态 〈 当 sleep 方法 被 调用 或 当 wait 方法 被 调用 或 当 被 VO 阻塞 ) 时 ， 上 面 介绍 
的 方法 就 不 可 用 了 。 此 时 可 以 使 用 interrupt 方法 来 打破 阻塞 的 情况 ， 当 interrupt 被 调用 的 时 
候 ， 会 抛 出 InterruptedException 异常 ， 可 以 通过 在 run 方法 中 捕获 这 个 异常 来 让 线程 安全 退 
出 ， 具 体 实现 方式 如 下 : 
public class MyThread 
{ 


public static void main(String[] args) 
{ 
Thread thread=new Thread(new Runnable() 
{ 
public void run() 
{ 
System.out.println("thread go to sleep"); 
try 
{ 


/用 休眠 来 模拟 线程 被 阻塞 
Thread.sleep(5000); 
System.out.println("thread finish"); 
} 
catch (InterruptedException e) 
{ 
System.out.println("thread is interupted!"); 
} 
} 
); 
thread. start(); 
thread.interrupt(); 


} 
旺 序 的 运行 结果 关 


Ey 


thread go to sleep 


thread is interupted! 


如 果 程 序 因为 VO 而 停滞 ， 进 入 非 运 行 状态 ， 基 本 上 要 等 到 IO 完成 才能 离开 这 个 状态 ， 
在 这 种 情况 下， 无 法 使 用 interrupt 来 使 程序 离开 run 方法 。 需 要 使 用 一 个 替代 的 方法 ， 其 基本 
思路 也 是 触发 一 个 异常 ， 而 这 个 异常 与 所 使 用 的 WO 相关 ， 例 如 ， 如 果 使 用 readLine 方法 
(readLine 方法 是 BufferedReader 中 一 个 非常 常用 的 方法 ， 使 用 它 可 以 从 一 段 输入 流 中 一 行 一 
行 地 读数 据 ， 行 的 区 分 用 "rr"、"\n" 或 者 "rn") 在 等 待 网 络 上 的 一 个 信息 ， 此 时 线程 处 于 阻塞 
状态 。 让 程序 离开 run 的 方法 就 是 使 用 close 方法 来 关闭 流 , 在 这 种 情况 下 会 引发 IOException 


异常 ，run 方法 可 以 通过 捕获 这 个 异常 来 安全 结束 线程 。 
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10. 答案 : 本 题 主 要 考察 的 是 对 藤 套 SQL 语句 的 掌握 情况 。 


Select distinct name from Score a where not exists(select * from Score b where 


b.name=a.name and b.mark<=75) 
三 、 编 程 题 
1. 答案 : 对 于 这 道 题 ， 可 以 从 右 下 角 开 始 倒 着 来 分 析 : 最 后 一 步 到 达 arr[m-1][n-1] 只 有 
两 条 路 ， 即 通过 arr[m-2][n-1] 到 达 或 通过 arr[m-1][n-2] 到 达 ， 假 设 从 arr[0][0] 到 arrfm-2][n-1] 
沿途 数组 最 小 值 为 fem-2,n-1)， 到 arr[m-1][n-2] 沿途 数组 最 小 值 为 ftm-1,n-2)。 因 此 ， 最 后 一 
步 选择 的 路 线 为 min{ flm-2,n-1), fm-lLn-2)}。 同 理 ， 选 择 到 arrfm-2][n-1] 或 arrfm-1][n-2] 的 路 
径 可 以 采用 同样 的 方式 来 确定 。 
此 可 以 推广 到 一 般 的 情况 。 假 设 到 arrfi-1] 四 与 axr[i][j-1] 的 最 短路 径 的 和 为 fi-1j) 和 
flij-1)， 那 么 到 达 arr 自 中 的 路 径 上 所 有 数字 和 的 最 小 值 为 f6,j)=min{ Ki-1j), fG,j-1)} + arr[i][0j]。 
方法 1: 递归 法 
根据 这 个 递归 公式 可 知 , 可 以 采用 递归 的 方法 来 实现 ,递归 的 结束 条 件 为 侦 历 到 arr[0][0]。 
在 求解 的 过 程 中 ， 还 需要 考虑 另外 一 种 特殊 情况 : 遍历 到 arr[i]j]〈 当 运 0 或 =0) 时 ， 只 能 沿 
着 一 条 固定 的 路 径 倒 着 往 回 走 直到 arr[0][0]。 根 据 这 个 递归 公式 与 递归 结束 条 件 可 以 给 出 实 
现代 码 如 下 : 


public class Test 
{ 
public static int get MinPath(int[][] arr, int i, int j) 
{ 
// 倒 着 走 到 了 第 一 个 结 点 ， 递 归结 束 
if(i1==0 &&]j==0) 
return arr[i][j]; 
/选取 两 条 可 能 路 径 上 的 最 小 什 
else if (1>0&&]j>0) 
return arr[i][j] + Math.min(get MinPath(arr, 1 - 1, j), get MinPath(arr, i, j - 1)); 
/下 面 两 个 条 件 只 有 一 条 路 可 选 
else if (1>0&&]==0) 
return arr[i]D] + getMinPath(arr, 1 - 1, j); 
/j>0&&i==0 
else 


return arr[i][j] + getMinPath(arr, 1, j - 1); 
} 


public static int get MinPath(int[][] arr) 
{ 
if(arr == null || arr.length==0) 
return 0; 
return get MinPath(arr,art.length-1,arr[0].length-1); 
} 


public static void main(String[ | args) 
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{ 
int[][] arr ={ 
{ 1, 4, 3}, 
{8,715 3}; 
121 
上 
System.out.println(getMinPath(arr)); 


} 


} 


星 序 的 运行 结果 为 
17 


这 种 方法 虽然 能 得 到 题目 想 要 的 结果 ， 但 是 效率 太 低 ， 因 为 里 面 有 大 量 的 重复 计算 过 
程 ， 比 如 在 计算 -1j) 与 位 -1 的 过 程 中 都 会 去 计算 fli-1j-1)。 如 果 把 第 一 次 计算 得 到 的 
f(i-1;j-1) 绥 存 起 来 就 不 需要 额外 的 计算 ， 而 这 也 是 典型 的 动态 规划 的 思路 ， 下 面 重点 介绍 动 
态 规划 方法 。 

方法 2: 动态 规划 法 

动态 规划 其 实 也 是 一 种 空间 换 时 间 的 算法 ， 通 过 缓存 计算 的 中 间 值 ， 从 而 减少 重复 计算 
的 次 数 ， 从 而 提高 算法 的 效率 。 方 法 1 从 arr[m-1][n-1] 开 始 逆向 通过 递归 来 求解 ， 采 而 动态 规 
划 要 求 正 向 求解 ， 以 便利 用 前 面 计算 出 来 的 结果 。 

对 于 本 题 而 言 ， 显 然 ，f(i,0)=arr[0][0]+*…+arr[ 订 [0]， 玫 0,j]= arr[0][0]+…+arr[0][j]。 根 据 递 
公式 :fj)=min{f Wi-1j), fj-])} 二 ar 四， 从 证 1， 二 1 开始 顺序 遍历 二 维 数组 ， 可 以 在 遍 
历 的 过 程 中 求 出 所 有 的 fj) 的 值 ， 同 时 ， 把 求 出 的 值 保存 到 另外 一 个 二 维 数组 中 以 供 后 续 使 
用 。 当 然 ， 在 遍历 的 过 程 中 可 以 确定 这 个 最 小 值 对 应 的 路 线 ， 在 这 个 算法 中 ， 除 了 求 出 最 小 
直 外 顺便 还 打印 出 了 最 小 值 的 路 线 ， 实 现代 码 如 下 : 


Ey 


Ey 


public class Test 
{ 
public static int get MinPath(int[][] arr) { 
if(arr == null || arr.length==0) 
return 0; 
int row = atr.length; 


int col = arr[0].length; 


// 用 来 保存 计算 的 中 间 值 
int[][] cache = new int[row][col]; 
cache[0][0] = arr[0][0]; 


一 


for(int 二 1; i<col; i++) 
{ 
cache[0][i] = cache[0][i-1] + arr[O][]; 


} 


for(int j=1; j<row; j++) 


{ 
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cache[j][0] = cache[j-11[0] + arrD][0]; 
} 


/在 遍历 二 维 数组 的 过 程 中 不 断 把 计算 结果 保存 到 cache 中 
for(int i=1; i<row; i++) 


{ 


for(int j=1; j<col; j++) 
{ 
/可 以 确定 选择 的 路 线 为 arr[i][j-1] 
这 cache[i-1]D] > cachefi]D-1]) 
{ 
cacheli][j] = cachefi][j-1] + arr[]D]; 
System.out.print("["+i+","+(G-1)+"] 站; 


} 

/可 以 确定 选择 的 路 线 为 arr[i-1][j] 

else 

{ 
cachef[ilD] = cachefi-1]0] + arr[i]0]; 
System.out.print("["+(i-1)+","++"]  "); 


} 
} 
System.out.println("["+(row-1)+","+(col-1)+"]"); 
return cache[row-1][col-1]; 


} 
public static void main(String[] args) 
{ 
int[][] arr ={ 
{1,4,3}, 
{ 8, 7, 5}, 
{1 53 
上 
System.out.print(" 路 径 :， "); 
System.out.printtn(" 最 小 值 为 : "+getMinPath(arr)); 
} 


程序 的 运行 结果 大 

路 径 :; [0,1] [0,2] [2,0] [2,1] [2,2] 

最 小 值 为 : 17 

这 种 方法 对 二 维 数组 进行 了 一 次 遍历 ， 因 此 ， 其 时 间 复 杂 度 为 OCm*n)。 此 外 由 于 这 个 算 
法 同样 申请 了 一 个 二 维 数组 来 保存 中 间 结 果 ， 因 此 ， 其 空间 复杂 度 也 为 O(m*n)。 


2. 答案 : 


public class Singleton 
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private static Singleton instance; 
private Singleton (| {} 
public static synchronized Singleton getInstance() 
{ 
if (instance — null) { 
instance = new Singleton(); 
} 


return instance; 


i 


} 
这 种 写法 虽然 是 多 线程 安全 的 ， 但 是 每 次 使 用 getInstance 方法 都 需要 进行 同步 ， 因 此 ， 
效率 比较 低 。 


public class Singleton 


{ 


private volatile static Singleton singleton; 


private Singleton() { 


} 
public static Singleton getSingleton() 
{ 
if (singleton =— null) { 
synchronized (Singleton.class) 
{ 
if (singleton == null) 
{ 
singleton = new Singleton(); 
} 
} 
} 
return singleton; 
} 


} 


这 种 方法 会 首先 判断 singleton 是 否 为 室 ， 如 果 这 个 对 象 一 旦 被 创建 ， 在 后 期 的 调用 过 程 
FP 就 不 会 进入 同步 的 代码 ， 因 此 ， 有 更 高 的 效率 。 

四 、 设 计 题 

1. 答案 : 本 题 考察 的 是 对 模板 设计 模式 的 理解 ， 分 析 如 下 : 

模板 设计 模式 是 指 在 一 个 方法 中 定义 一 个 简单 的 算法 骨架 ， 而 将 一 些 步骤 延迟 到 子 类 ， 
实现 ， 模 板 方法 子 类 可 以 在 不 改变 算法 结构 的 情况 下 ， 重 新 定义 算法 中 的 某 些 步骤 。 实 现 类 
图 如 图 23 所 示 。 


bf 
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AbstractClass 
primitive0perationl (); 


+templateMethod () primitiveOperation2() ; 
+primitive0perationl () 
+primitiveOperation2() 


ContreteClassl 


+primitiveOperationl () 
+primitive0peration2() 


ContreteClass2 


+primitive0perationl () 
+primitiveOperation2() 


图 23 模板 设计 模式 实现 类 图 


AbstractClass 为 模板 抽象 类 ， 这 个 抽象 类 中 定义 了 两 个 抽象 方法 primitiveOperationl 和 
primitiveOperation2， 同 时 定义 了 算法 的 骨架 templateMothod 方法 ， 这 个 方法 内 按照 顺序 调用 
了 primitiveOperationl 和 primitiveOperation2 方法 ， 实 现 了 算法 的 结构 。 这 两 个 方法 的 具体 实 
现 细节 由 子 类 来 决定 。 

通过 对 模板 设计 模式 进行 研究 发 现 ， 本 题 所 描述 的 系统 非常 适合 采用 模板 设计 模式 来 实 
现 ， 实 现 类 图 如 图 24: 


validateUser () ; 
welcome () ; 


MobileBank 


+validateUser () 
+Welcome () 


OnLineBack 


图 24 ”本题 的 实现 类 图 


其 中 ，Bank 类 定义 了 银行 登录 的 流程 ，login 方法 的 方法 体 为 : 调用 validateUser 验证 
户 的 登录 信息 ， 当 登录 成 功 后 ， 调 用 welcome 进入 欢迎 界面 ; 

对 于 手机 银行 的 子 类 MobileBack, validateUser 方法 采用 用 户 名 和 密码 的 方式 来 验证 用 户 
的 合法 性 ，welcome 方法 内 实现 手机 银行 的 欢迎 界面 ; 

对 于 网 上 银行 的 子 类 OnLineBack，validateUser 方法 采用 UKEY 或 者 文件 证 书 来 验证 用 
户 的 合法 性 ，welcome 方法 内 实现 网 页 的 欢迎 界面 。 

如 果 后 期 有 其 他 的 接 入 方式 ， 只 需要 继承 Bank 类 ， 同 时 实现 这 两 个 抽象 方法 即 可 。 

2. 答案 : 本 题 考察 的 是 对 观察 者 模式 的 理解 。 对 于 观察 者 模式 的 介绍 ， 请 参见 前 面 真题 
中 的 介绍 。 


吾 
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对 于 本 题 而 言 ， 可 以 采用 下 面 图 25 所 示 的 类 图 来 3 


“<《interface>> 
Observer 


<“<interface>> 
Subject 
tregisterObserver () 
tremoveObserver () 
tnotifyObservers() 


+registerObserver () 
IremoveObserver () 
+notifyObservers() 


+dataChanged () 


图 25 ”实现 类 图 


Subject 为 主题 接口 ， 定 义 了 主题 的 基本 操作 。 

DbData 为 具体 的 主题 , 这 个 类 的 功能 是 当 数 据 库 中 有 数据 变化 时 就 调用 dataChange 方 法 ， 
这 个 方法 会 调用 notifyObservers 方法 ， 而 这 个 方法 会 调用 所 有 注册 的 观察 者 的 update 方法 来 
把 最 新 更 改 的 数据 通知 到 所 有 的 观察 者 (例如 TableDisplay、BarDisplay 等 ), 观察 者 的 update 
方法 会 调用 内 部 的 display 方法 把 新 的 数据 显示 到 界面 上 。 

Observer 为 观察 者 接口 , 关心 数据 库 数据 变化 的 类 都 需要 实现 这 个 接口 中 的 update 方法 ， 
只 要 实现 这 个 接口 的 观察 者 对 主题 进行 了 注册 ， 当 数据 库 中 数据 发 后 变化 时 ， 这 个 观察 者 的 
update 方法 就 会 被 调用 来 更 新 数据 。 

Display 接口 为 数据 显示 的 接口 ,display 方法 用 来 把 从 数据 库 中 拿 到 的 数据 显示 出 来 ,save 
方法 用 来 把 对 数据 的 修改 保存 到 数据 库 中 。 

对 于 本 题 而 言 ， 只 需要 三 个 具体 的 观察 者 ， 分 别 为 以 表格 形式 显示 的 观察 者 、 以 柱状 图 
格式 显示 的 观察 者 和 以 饼 图 方式 显示 的 观察 者 。 以 表格 形式 显示 的 观察 者 为 例 ， 在 这 个 类 的 
update 方法 中 ， 可 以 把 数据 库 更 新 的 新 的 数据 保存 到 dataObj 属性 中 ， 同 时 可 以 调用 display 
方法 来 把 数据 以 表格 的 方式 显示 出 来 。 当 表格 中 的 数据 有 变化 时 ， 可 以 调用 save 方法 把 变化 
的 数据 保存 到 数据 库 中 。 当 数据 库 中 的 数据 有 变化 时 ， 又 会 通知 所 有 的 观察 者 更 新 数据 。 


al 及 某 项 级 生活 消费 类 网 站 软件 工程 师 笔 试题 


1. 答案 : 如 果 没 有 时 间 复 杂 度 的 要 求 ， 本 题 可 以 采用 传统 的 插入 排序 或 快速 排序 等 方法 
进行 排序 ， 但 是 传统 的 排序 方法 在 最 好 的 情况 下 的 时 间 复 杂 度 都 为 O(nlog n)， 显 然 ， 不 满足 
题目 要 求 的 OOD) 时 间 复 杂 度 。 对 于 对 时 间 复 杂 度 有 很 高 要 求 的 问题 ， 一 般 可 以 考虑 用 空间 换 
时 间 的 方法 。 鉴 于 此 ， 对 于 本 题 而 言 ， 可 以 采用 如 下 思路 : 
通常 ， 字 母 为 26 个 ， 当 区 分 大 小 写 后 ， 变 为 26X2=52 个 ， 所 以 ， 首 先 申 请 一 个 长 度 为 
52 的 int 型 数组 ， 按 照 aAbBcC...zZ〔 小 写字 母 保 存在 下 标 为 偶数 的 位 置 ， 大 写字 母 保存 在 下 
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标 为 奇数 的 位 置 ) 的 顺序 依次 记录 各 个 字母 出 现 的 次 数 ， 当 记录 完成 以 后 ， 就 可 以 所 历 这 个 
数组 来 按照 各 个 字母 出 现 的 次 数 来 重组 排序 后 的 数组 ， 实 现代 码 如 下 : 


public class Test 


{ 
public static void main(String[] args) 
' 
char[] src= { 'R', 'B, 'B', vb, WwW,, WwW,, 'B', 'R', 'B, ‘Ww! 入 
sort(src); 
for (int 1=0;i<src.length;i++) 
{ 
System.out.print(src[i] + " "); 
} 
} 
private static void sort(char[] src) 
ifsrc — null) 
{ 
System.out.println(" 参 数 不 合法 "); 
return; 
} 
/用 于 保存 52 个 字符 出 现 的 次 数 ， 小 写字 母 保存 在 下 标 为 偶数 的 位 置 ， 大 写字 母 保 
/存在 奇数 的 位 置 


/采用 这 种 保存 方法 ， 可 以 保证 在 这 个 数组 中 小 写字 母 出 现在 大 写字 母 前 面 ， 小 的 字 
// 符 出 现在 大 的 字符 前 面 
int[] charCount = new int[S4]; 
for (int i= 0; i<src.length; i++) 


{ 


// 对 小 写字 母 出 现 的 次 数 就 行 计数 
if (src[i] >'a'&&zsrc[i] <'Zz) 
{ 


charCount[(src[i] - 'a) * 2]++; 


} 


// 对 大 写字 母 出 现 的 次 数 就 行 计数 
else if (src[i] <Z'&&src[i] >'A') 
{ 


charCount[(src[i] - 'A') * 2 + 1]++; 
} 
} 
/根据 各 个 字符 出 现 的 次 数 按 顺序 生成 排序 后 的 字符 数组 
int index = 0; 
for (int i= 0; i<charCount.length; i++) 


{ 


// 这 个 字符 在 原始 字符 数组 中 存在 
if (charCount[i] != 0) 
{ 
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/小 写字 母 
if(i% 2==0) 
{ 


for (int j = 0; ] <charCount[ji]; j++) 


{ 


src[index++] = (char) (i /2 +'a'); 


} 


1 
3 

/大 写字 母 
else 


{ 


for (int j = 0; ] <charCount[i]; j++) 


{ 


src[index++] = (char) ((i- 1)/2+'A"); 


} 


> 


旺 序 的 运行 结果 关 


bBBBBRRwWW 


2. 答案 : 495。 
分 析 : 本 题 考察 的 是 排列 组 合 的 知识 。 


题 只 


需 
的 是 家 属 
要 选 出 4 


2 


于 参加 活动 的 每 个 员工 的 家 属 是 确定 的 ， 


， 则 mo-Da-2)(3X2)-220， 解 出 n=12， 


旦 员工 选 好 了 ， 家 属 也 就 确定 了 。 因 此 ， 


要 考虑 选 出 指定 员工 个 数 的 组 合 数 就 可 以 了 。 假设 这 20 个 人 中 有 mn 个 是 员工 ， 其余 


因此 ， 总 


有 12 个 员工 ，8 个 家 属 。 如 果 


个 专家 和 家 属 ， 那 么 组 合 数 为 (12X11X10X9)/(4X3X2)=495。 


3. 答案 : 本 题 的 主要 思路 如 下 : 对 所 有 的 分 区 进行 遍历 ， 同 时 用 一 个 变量 dIndex 记录 


有 足够 的 
适 的 磁盘 


上 次 分 配 磁盘 的 下 标 ， 初 始 化 为 0; 对 了 


每 个 分 区 ， 从 上 次 分 配 的 磁盘 开始 继续 分 配 ， 如 果 没 


空间 ， 则 顺序 找 其 他 的 磁盘 ， 直 到 找到 合适 的 磁盘 为 止 ， 进 行 分 配 ， 如 果 找 不 到 合 


， 则 分 配 失败 ， 实 现代 码 如 下 : 


public class Test 
{ 
public static void main(String[] args) 
{ 
int[] d = {120, 120, 120 };// 磁盘 
int[] p = { 60, 60, 80, 20, 80 };// 分 区 
if (is allocable(d, p)) 
{ 


System.out.println(" 分 配 成 功 "); 


} else 


252 


真题 详解 篇 


{ 
System.out.printIn(" 分 配 失败 "); 
} 
} 
private static boolean is_allocable(int[] d, int[] p) 
{ 
int dIndex=0; /磁盘 分 区 下 标 
for(int 1=0;i<p.length;i++) 
{ 
/找到 符合 条 件 的 磁盘 
while(dIndex<d.length&& p[i]> d[dIndex]) 
{ 
dlIndext+; 
} 
/没有 可 用 的 磁盘 
这 dIndex>=d.lengtb) 
return false; 
/给 分 区 分 配 磁盘 
d[dImdex]-=p[]; 
} 
return true; 
} 
} 
程序 的 运行 结果 为 
分 配 成 功 


4. 答案 本题 的 思路 为 从 右上 和 角 开 始 对 数组 中 的 元 素 经 行 输出 ， 实 现代 码 如 下 : 


public class Test 
{ 
private static void rotateArr(int[][] arr) { 
int row, col; 
int len=arrlength; 
/ 打印 二 维 数组 右上 半 部 分 


for (inti= len- 1; > 0; 1--) 


{ 
row = 0; 
col=1; 
while (col <len) 
{ 
System.out.print(arr[row++][col++]+" "); 
} 
System.out.println(); 
} 


/ 打印 二 维 数组 左下 半 部 分 〈 包 括 对 角 线 ) 
for (inti= 0; ij<len; i++) 
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TOW = 1; 
col=0; 
while (row <len) 
{ 
System.out.print(arr[row++][col++]+" "); 
} 
System.out.println(); 
} 
} 
public static void main(String[] args) 
{ 
int[][] arr = {{1,2,3},{4,5,6},{7,8,9}}; 
rotateArr(arr); 
} 
} 
程序 的 运行 结果 为 
3 
26 
159 
48 
7 


5. 答案 : 本 题 最 简单 的 方法 就 是 对 于 表达 式 的 每 个 项 计算 一 个 值 ， 然 后 相 加 ， 这 种 方法 
显然 需要 大 量 的 乘法 运算 ， 因 此 ， 效 率 比 较 低 下 。 下 面 介 绍 另 外 一 种 能 减少 乘法 运算 次 数 的 
方法 ， 对 于 这 个 表达 式 的 计算 可 以 分 为 如 下 两 种 情况 进行 处 理 : 

1) 当 n 为 奇数 时 ， 首 先 ， 计算 1+x 的 值 ， 并 保存 到 一 个 临时 变量 中 ， 然 后 用 这 个 值 乘 以 
x^2 就 可 以 得 到 后 面 两 项 x^2+x^3， 把 这 个 值 保 存 到 临时 变量 中 ， 再 乘 以 x^2 又 可 以 得 到 后 面 
两 项 的 值 ， 以 此 类 推 ， 就 可 以 得 到 所 有 项 的 值 ， 把 这 些 值 累加 就 可 以 得 到 表达 式 的 值 。 

2) 当 n 为 偶数 时 ， 首 先 计 算 x+x^2 的 值 ， 然 后 用 同样 的 方法 计算 后 面 的 项 并 累加 ， 最 后 
再 加 1， 就 可 以 得 到 表达 式 的 值 。 

实现 代码 如 下 : 


public class Test 


{ 
private static int calculate(int x, int n) 
{ 
int xPower; 
int sum = 0; 
int tmp = 0; 


xPower =X * x; 
让 (n%2==1)//n 为 奇数 
{ 


tmp=1+x; 


sum += tmp; 
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for (inti= 1;1i<n;1i=1i+2) 
{ 
tmp *= xPower; 
sum += tmp; 
} 
} 
else//n 为 偶数 
{ 
tmp = XxX+ xPower; 
sum 十 = tmp; 
for (inti=2;i<n;1i=1i+2) 
{ 
tmp *= xPower; 
sum += tmp; 
} 
sum += 1; 
} 
return sum; 
} 
public static void main(String[] args) 
{ 
System.out.println(calculate(2, 5)); 
} 
} 
程序 的 运行 结果 为 
03 


本 题 乘法 运算 的 次 数 大 概 为 W2。 因 此 ， 该 方法 的 时 间 复 杂 度 为 OO。 

6. 答案 : 假设 使 用 队列 ql 与 队列 q2 模拟 栈 S，ql 为 入 队列 ，q2 为 出 队列 。 

实现 思路 如 下 : 可 以 认为 队列 ql 提供 压 栈 的 功能 ， 队 列 q2 提供 弹 栈 的 功能 。 

当 要 压 栈 时 ， 入 队列 ql 即 可 ， 而 当 要 弹 栈 时 ， 出 队列 则 需要 分 为 以 下 两 种 情况 考虑 : 

1) 如 果 队 列 ql 中 只 有 一 个 元 素 ， 那 么 让 队列 ql 中 的 元 素 出 队列 并 输出 即 可 。 

2) 如 果 队 列 ql 中 有 多 于 一 个 元 素 ， 那 么 让 队列 ql 中 所 有 元 素 出 队列 ， 入 队列 92， 最 
后 一 个 元 素 不 入 队列 92， 输 出 该 元 素 ， 然 后 将 队列 q2 所 有 元 素 入 队列 ql 。 

实现 代码 如 下 : 


import java.util.Queue; 

import java.util.concurrent.LinkedBlockingQueue; 

public class MyStack<T> 

{ 
private Queue<T>q1= new LinkedBlockingeQueue<T>();; 
private Queue<T>q2= new LinkedBlockingQueue<T>(); 
public void push(T value) 
{ 


ql.add(value); 
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} 
public boolean empty() 
{ 
这 ql.isEmptyO) 
return true; 
else 
return false; 
} 
public T popO) 
{ 
if(ql.size()==0) 
return null; 
else if(q1.size()==1) 
return q1.poll(); 
else 
{ 
while(q1.size()>1) 
q2.add(q1.pollO); 
T result=g1.poll(); 
while(!q2.isEmpty()) 
ql.add(q2.pollO); 
return result; 
} 
} 
public static void main(String[] args) 
{ 
MyStack<Integer> stack = new MyStack<Integer>(); 
stack.push(1); 
stack.push(2); 
stack.push(3); 
System.out.println(stack.pop(); 
stack.push(4); 
System.out.println(stack.pop(); 
} 
} 
程序 的 运行 结果 为 
3 
4 


答案 ; 本题 可 以 采用 贪心 法 来 解决 ， 有 具体 实现 思路 如 下 : 

申请 一 个 数组 来 记录 每 台 机 器 的 执行 时 间 ， 初 始 化 为 0， 在 调度 任务 的 时 候 ， 对 于 每 个 
任务 ， 在 选取 机 器 时 采用 如 下 的 贪心 策略 : 对 于 每 台 机 器 ， 计 算 机 器 已 经 分 配 任务 的 执行 时 
间 + 这 个 任务 需要 的 时 间 ， 选 用 最 短 时 间 的 机 器 进行 处 理 。 实 现代 码 如 下 : 


[ 


7 


public class Test 


{ 
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public static void main(String[] args) 
{ 
int t[] = {7,10}; 
intn=6; 
int proTime[] = calculate process time(t , D); 
if(proTime==null) 
{ 
System.out.println(" 分 配 失败 7); 
return; 
} 
int total Time=proTime[0]; 
for (int1= 0; 1< proTime.length; i++) 
{ 
System.out.printIn(" 第 "十 (i 十 1)+" 人 台 服 务 器 有 "二 proTime[i]/t[] + "个 任务 ， 
执行 总 时 间 为 : "+ proTime[i); 
if(proTime[i]>totalTime) 
totalTime=proTime[j]; 


} 

System.out.println(" 执 行 完 所 有 任务 所 需 的 时 间 为 " + totalTime); 
} 
/* 米 


* (@param t 每 个 服务 器 处 理 的 时 间 
* (Oparam n 任务 的 个 数 
* (@return 各 个 服务 器 执行 完 任务 所 需 的 时 间 
$/ 
private static int[] calculate_process_ time(int[] t, int n) 


{ 


if(({=——null | n<=0) 
return null; 
int m=t.length; 
int minIndex:; 
int minTime; 
int[] proTime=new int[m]; 
for (inti=0;1<n;1++) 


{ 
minTime = proTime[0] +t[0]; /把 任务 给 第 j 个 机 器 上 后 这 个 机 器 的 执行 时 间 
minIndex = 0; // 把 任务 给 第 minIndex 个 机 器 上 
for (intj = 1;j<m; j++) 
{ 


/分 配 到 第 j 台 机 器 上 后 执行 时 间 更 短 
if (minTime > proTime[]+ 吉 了]) 


{ 


minTime = proTime[j] + tD]; 
minIndex = j; 


= 一 
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} 


return proTime; 


} 


proTime[minIndex] += t[minIndex]; 


Ey 


星 序 的 运行 结果 六 


第 1 台 服 务 器 有 4 个 任务 ,执行 总 时 i 
第 2 台 服 务 器 有 2 个 任务 ,执行 总 时 
执行 完 所 有 任务 所 需 的 时 间 为 28 


mH 蕊 | 


20 


. 答案 : 算法 的 主要 思路 为 : 从 当前 字符 串 出 发 找 


8 
前 字符 串 的 最 小 字符 串 )。 


下 一 个 排列 〈 下 一 个 排列 为 大 于 当 


通过 引入 一 个 例子 来 介绍 非 递 归 算 法 的 基本 思想 : 假设 要 对 字符 串 “12345” 进 行 排序 。 


第 一 个 排列 一 定 是 “12345”, 依 此 获取 下 一 个 排列 : “12345”->“12354”->“12435”->“12453” 


-> “12534”->“12543”->“13245”->…。 从 “12543”->“13245” 可 以 看 出 找 下 一 个 排列 


的 主要 思路 如 下 : 
1) 从 右 到 左 找到 两 个 相 邻 递增 的 字符 ， 


3) 为 了 保证 下 一 个 排列 为 大 于 当前 字符 


在 本 例 中 ,“12543” 中 从 右 到 左 找 出 第 一 个 相 邻 

递增 的 子 串 为 “25”， 记录 这 个 小 的 字符 的 下 标 为 pmin。 
2) 找 出 pmin 后 面 的 比 它 大 的 最 小 的 字符 进行 交换 ， 在 本 例 中 ， 字 符 “2” 后 面 的 子 串 中 

比 它 大 的 最 小 的 字符 为 “3”， 因 此， 交换 字符 “2” 和 字符 “3” 可 以 得 到 字符 串 “13542”。 


的 最 小 字符 串 ， 在 第 2) 步 完成 交换 后 ， 需 要 


对 pmin 后 的 子 串 重新 组 合 ， 使 其 值 最 小 ， 只 需 对 pmin 后 面 的 字符 进行 逆序 即 可 《 


pmin 后 面 的 子 串 中 的 字符 必定 是 按照 降序 提 


因为 此 时 


FE 列 ， 逆 序 后 字符 就 按照 升序 排列 了 )， 


逆序 后 就 


能 保证 当前 的 组 合 是 新 的 最 小 的 字符 串 ， 在 这 个 例子 中 ， 上 一 步 得 到 的 字符 串 为 “13542”， 


pmin 指向 字符 “3” 对 其 后 面 的 子囊 “542” 


4) 依次 类 推 ， 直 到 获取 到 字典 序 为 k 的 排列 为 止 。 


逆序 后 得 到 字符 串 “13245 ”。 


T 


,intj) 


实现 代码 如 下 : 
public class Test 
{ 
/ 交换 数组 arr 中 下 标 为 i 和 j 对 应 的 字符 
private static void swap(int[] arr, int i 
{ 
int tmp = arr[il; 
arr[i] = arr[j}; 
arr[j] = tmp; 
} 


{ 


/村 下 洒 六 六 于 于 宗 玉 汶 夺 叶 环 太太 于 六 入 六 天 来 守 玉 玉环 芝 素来 来 于 于 六 束 术 六 玉环 来 本 汪 来 于 再生 当 六 于 水 玉 六 于 检 奈 味 玉 六 过 兴 来 续 呆 来 六 张 叶 中 玉 率 来 夺 秦 汪 太 来 浊 六 


* 函 数 功 能 ， 翻 转 数 组 输入 参数 ，begin 与 end 分 别 为 字符 串 的 第 一 个 字母 与 最 后 一 个 字母 


于 六 六 米 率 术 亲 六 玉 汪 汪 六 六 玉林 本 宁 六 六 玉林 六 六 玉 六 来 间 六 玉 演 亲 汪 六 浅水 六 过 六 水 玉 本 水 于 玉 玉 六 六 蒜 玉 六 林寺 六 六 本 永 洒 玉 来 六 本 于 夺 玉 六 来 六 达 玉 六 洲 来 来 浅 六 玉 / 


private static void Reverse(int[] arr, int begin, int end) 
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while (begin < end) 
swap(arr, begin++, end--); 


/ 获取 下 一 个 字典 序 的 排列 
private static boolean getNextPermutation(int arr[]) 
{ 

if (arr == null || arrlength == 1) 

return false; 

int end = arr.length - 1; 

int cur = end; // 用 来 从 后 向 前 遍历 数组 

int suc = -1; // cur 的 后 继 字 符 

int tmp = -1; 

while (cur != 0) 

{1/ 从 后 向 前 开始 遍历 数组 


SUC = cur; 


CUr--; 
if (arr[cur] < arr[suc]) 
{/ 相 邻 递增 的 字符 ，cur 指向 较 小 的 字符 
// 找 出 cur 后 面 最 小 的 字符 tmp 
tmp = end; 


while (arr[tmp] < arr[cur]) 
--tmp; 

// 交换 cur 与 tmp 

swap(art, cur, tmp); 

/ 把 cur 后 面 的 子 字符 串 ; 

Reverse(arr, suc, end); 

return true; 


Ld 


行 翻转 


} 


return false; 


= 一 


/ 获取 下 字典 序 为 k 的 排列 


public static String Permutation(int arr[], int k) 


do 
{ 
if (k == 0) 
{ 
String result = ""; 
for (inti= 0; i1< arr.length; i++) 
result += arr[i]; 
return result; 
} 
kK 
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}while(getNextPermutation(arr)); 


return null; 


} 


public static void main(String[ | args) 
{ 
int n= 3;//n 个 元 素 
intk=4;// 第 k 个 排列 
int arr[] = new int[m]; 
for (inti=0;1< arr.length; 1i++) 
arr[i] =1+ 1; 
String result = Permutation(arr, k); 
if (result != null) 
System.out.println(" 字 典 序 为 "+k+" 的 排列 为 :"+ resulb); 


else 
System.out.println(" 不 存在 由 ; 


} 


程序 的 运行 结果 为 
字典 序 为 4 的 排列 为 :312 


ua 是 LA 某 知名 门户 网 站 软件 工程 师 笔 试题 


一 、 选 择 题 

1. 答案 : A、C、D。 

分 析 : 本 题 考察 的 是 Exception 类 的 知识 。 

对 于 选项 A， 在 Java 语言 中 ，java.lang.Exception 类 是 所 有 异常 的 直接 或 间接 父 类 ， 即 
Exception 类 是 所 有 和 异常 的 根 类 。java.lang.Throwable 类 是 在 Java 语言 中 所 有 错误 和 异常 的 超 
类 。Exception 类 的 定义 为 public class Exception extends Throwable， 而 Throwable 的 定义 为 
public class Throwable extends Objectimplements Serializable。 由 此 可 见 , Exception 是 公共 类 (被 
public 修饰 )。 因 此 ， 选 项 A 正确 。 

对 于 选项 B 与 选项 C，Exception 是 Throwable 的 子 类 ，Throwable 是 类 而 不 是 接口 。 因 
此 ， 选 项 B 错误 ， 选 项 C 正确 。 

对 于 选项 D， 由 于 Throwable 实现 了 Serializable 接口 ， 因 此 ， 可 以 被 序列 化 。 如 果 一 个 
类 能 被 序列 化 ， 那 么 它 的 子 类 也 能 够 被 序列 化 。 因 此 ，Exception 类 也 可 以 被 序列 化 。 因 此 ， 
选项 D 正确 。 

所 以 ， 本 题 的 答案 为 A、C、D。 

2. 管 案 : C。 

分 析 : 本 题 考察 的 是 Java 语言 中 Thread 类 的 知识 。 

在 Java 语言 中 ，Thread 类 位 于 java.lang 命名 空间 下 。Thread 类 主要 用 于 创建 并 控制 线程 、 
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设置 线程 优先 级 并 获取 其 状态 。 

本 题 中 ， 对 于 选项 A， 要 实现 多 线程 ， 在 继承 了 Thread 类 后 必须 实现 run() 方 法 ， 也 就 是 
说 ， 线 程 的 核心 逻辑 都 存在 于 run() 方 法 中 。 这 个 方法 被 start() 方 法 调用 来 实现 多 线程 的 功能 ， 
如 果 直 接 调用 run0) 方 法 ， 那 么 就 与 调用 普通 的 方法 类 似 。 所 以 ， 选 项 A 错误 。 
对 于 选项 B，Thread 类 提供 了 一 个 start0 方 法 ,该 方法 的 功能 是 让 这 个 线程 开始 执行 ， 当 
开始 执行 后 , JVM 将 会 调用 这 个 线程 的 run0 方 法 来 执行 这 个 线程 的 任务 。 所 以 , 选项 B 错误 。 

对 于 选项 C，Thread 类 没有 exit0 这 个 方法 。 所 以 ， 选 项 C 正确 。 

对 于 选项 D, Thread 类 的 stop0 方 法 是 用 来 停止 一 个 线程 的 , 但 是 由 于 这 个 方法 不 是 线程 
安全 的 ， 因 此 ， 通 常 不 推荐 使 用 。 所 以 ， 选 项 D 错误 。 

所 以 ， 本 题 的 答案 为 C。 

3. 答案 : B。 

分 析 : 本 题 考察 的 是 字符 串 知识 。 
在 Java 语言 中 , String 是 一 个 类 , 因此 , 它 的 对 象 strl 和 str2 都 是 引用 。 当 语句 String strl 
= "abcd" 执 行 后 ， 字 符 串 “abcd” 会 保存 在 常量 区 ， 而 strl 只 是 这 个 字符 串 的 一 个 引用 (可 以 
理解 为 地 址 )。 当 语句 String str2 = "ab" + new String("cd") 执 行 后 ， 由 于 是 采用 new 方法 创建 字 
符 串 ， 因 此 ， 会 首先 创建 一 个 字符 串 “cd”， 接 着 与 字符 串 “ab” 拼 接生 成 另外 一 个 新 的 字符 
串 “abcd”， 并 且 这 个 字符 串 是 存储 在 堆 空 间 中 的 。str2 是 这 个 字符 串 的 引用 《可 以 理解 为 地 
址 )， 由 于 这 两 个 字符 串 保存 在 不 同 的 存储 空间 中 ， 因 此 ， 二 者 的 内 存 地 址 是 不 同 的 ， 所 以 ， 
strl 与 str2 不 相等 ， 输 出 false。 

如 果 把 代码 改 成 String str2 = "abcd"， 那 么 输出 的 结果 为 true。 因 为 采用 这 种 初始 化 方式 ， 
会 首先 在 常量 区 里 去 查找 是 否 存 在 这 个 字符 串 ， 如 果 存 在 ， 则 str2 直接 就 为 这 个 字符 串 的 引 
用 ， 如 果 不 存在 ， 才 会 在 常量 区 里 创建 新 的 字符 串 “abcd”。 当 strl 被 初始 化 后 ， 再 用 这 种 方 
式 初 始 化 str2 时 ,常量 区 里 已 经 存在 字符 串 “abcd”， 因 此 ，str2 也 指向 相同 的 字符 串 ， 故 strl 
与 str2 是 相等 的 。 但 是 当 用 new 去 创建 对 象 时 ， 不 管 该 字符 串 是 否 存在 ， 每 次 都 会 在 堆 空 间 
里 申请 新 的 存储 空间 。 

如 果 要 比较 字符 串 的 内 容 是 否 相等 ， 可 以 使 用 String 类 的 equals 方法 ， 例 如 对 于 上 述 题 
目 ，System.errprintln(strl.equals(str2)) 的 输出 结果 为 true。 

所 以 ， 本 题 的 答案 为 B。 

4. 答案 : B。 

分 析 : 本 题 考察 的 是 Java 语言 中 Thread 类 的 知识 。 

Thread 类 提供 了 一 个 start0 方 法 ， 这 个 方法 的 功能 是 让 这 个 线程 开始 执行 ， 当 开始 执行 
后 ，JVM 将 会 调用 这 个 线程 的 run() 方 法 来 执行 这 个 线程 的 任务 。 如 果 直 接 调用 run() 方 法 就 
与 调用 普通 的 方法 类 似 。 

对 于 本 题 而 言 ， 首 先 调 用 trun0 方 法 ， 输 出 “world”， 等 调用 结束 后 才 会 执行 
System.out.print("hello") 语 句 ， 输 出 “hello”。 所以， 选项 B 正确 。 

如 果 把 trun0 改 成 tstart0， 在 调用 tstart() 方 法 后 不 需要 等 这 个 线程 结束 ， 这 个 方法 就 会 
立即 返回 ， 然 后 执行 语句 System.out.print("hello")。 在 这 种 情况 下 ， 这 两 个 输出 语句 的 执行 顺 
序 是 无 法 保证 的 ， 任 何 一 个 语句 都 有 可 能 先 执行 ， 此 时 答案 就 是 选项 C。 

所 以 ， 本 题 的 答案 为 了 B。 
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5. 答案 : A。 


分 析 : 本 题 考察 的 是 对 守护 线程 的 理解 。 


Java 语言 提供 了 两 种 线程 : 


守护 线程 与 用 户 线程 。 守 护 线程 又 被 称 为 “服务 进程 ”“ 精 灵 


线程 ”或 “后 台 线 程 ”， 是 指 当 程序 运行 时 ， 在 后 台 提 供 一 种 通用 服务 的 线程 ， 这 种 线程 并 不 


保姆 。 


届 于 程序 中 不 可 或 缺 的 部 分 。 通 俗 讲 ， 任 何 一 个 守护 线程 都 是 整个 JVM 中 所 有 非 守 护 线程 的 


用 户 线程 和 守护 线程 几乎 一 样 ， 唯 一 的 不 同 之 处 就 在 于 : 如 果 用 户 线程 已 经 全 部 退出 
运行 ， 只 剩 下 守护 线程 存在 ，Java 虚拟 机 也 就 退出 了 。 因 为 当 所 有 的 非 守护 线程 结束 时 ， 


没有 了 被 守护 者 ,守护 线程 也 就 没有 工作 可 做 ,也 就 没有 继续 运行 程序 的 必要 了 , 程序 也 就 
终止 了 ， 同 时 会 杀 死 所 有 和 守护 线程 。 也 就 是 说 ， 只 要 有 任何 非 守护 线程 还 在 运行 ， 程 序 就 不 


会 终止 


全 全 JJ 上 Lo 


在 Java 语言 中 ， 守 护 线程 


口 


般 上 共有 较 低 的 优先 级 ， 它 并 非 只 由 JVM 内 部 提供 ， 用 户 在 


编写 程序 时 ， 也 可 以 自己 设置 守护 线程 。 例 如 ， 将 一 个 用 户 线程 设置 为 守护 线程 的 方法 就 是 


在 调用 start 方法 启动 线程 之 前 调 月 


日 对 象 的 setDaemon(true) 方 法 , 如果 将 以 上 参数 设置 为 false， 
则 表示 的 是 用 户 进程 模式 。 需 要 注意 的 是 ， 当 在 一 个 守护 线程 中 产生 了 其 他 线程 ， 那 么 这 些 
新 产生 的 线程 默认 还 是 守护 线程 ， 


用 户 线程 也 是 如 此 。 


守护 线程 的 一 个 典型 的 例子 就 是 垃圾 回收 器 。 只 要 JVM 局 动 ， 它 就 始终 在 运行 ， 实 时 监 


控 和 管理 系统 中 可 以 被 回收 的 资源 。 


所 以 ， 选 项 A 正确 。 
所 以 ， 本 题 的 答案 为 A。 
6. 答案 : A、B。 


分 析 : 本 题 考察 的 是 数据 库 的 知 


口 


MAo 


根据 存储 模型 的 不 同 ， 数 据 库 主要 可 分 为 网 状 数据 库 、 关 系数 据 库 、 树 状 数据 库 、 面 向 
对 象 数据 库 和 层次 数据 库 等 。 关 系数 据 库 的 应 用 最 为 广泛 ， 关 系 式 数据 结构 是 指 把 一 些 复杂 


的 数据 结构 归结 为 简单 的 二 元 关系 〈 即 二 维 表格 形式 )。 例 如 菜单 位 的 职工 关系 就 是 一 个 二 元 


关系 。 常 见 的 关系 数据 库 有 Oracle、DB2、Sybase、SQL Server、Informax 及 MySQL 等 ， 非 


关系 型 数据 库 有 MongoDB、memcachedb 和 Redis 等 。 所 以 ， 选 项 A 和 选项 B 正确 。 


对 于 选项 C，MongoDB 是 目前 非常 流行 的 一 种 非 关 系 型 数据 库 (NoSql)， 它 有 非常 灵 
活 的 存储 方式 。 它 非常 好 地 实现 了 面向 对 象 的 思想 ， 在 MongoDB 数据 库 中 ， 每 一 条 记录 都 
是 一 个 Document 对 象 。 所 以 ， 选 项 C 错误 。 


对 于 选项 D，IMS 是 IBM 
时 系统。 所以， 选项 DD 错误 。 


中 


所 以 ， 本 题 的 答案 为 A、B。 


7. 答案 : B。 


层次 数据 库 ， 不 是 关系 数据 库 ， 它 是 最 早 的 大 型 数据 库 


分 析 : 本 题 考 察 的 是 关键 字 volatile 的 知识 。 
volatile 是 一 个 类 型 修饰 符 (Type Specifier)， 被 设计 用 来 修饰 被 不 同 线程 访问 和 修改 的 变 


量 。 对 于 不 被 volatile 修饰 的 成 员 变 


旦 ， 当 系统 每 次 使 用 到 它 的 时 候 ， 都 是 直接 从 对 应 的 内 存 
提取 ， 而 不 会 利用 缓存 。 在 使 用 了 关键 字 volatile 修饰 成 员 变 量 后 ， 在 读 取 数 据 时 可 能 从 组 


存 里 去 读 取 ， 如 果 其 他 线程 已 经 修改 了 这 个 数据 ， 则 无 法 读 取 到 修改 后 的 数据 。 
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需要 注意 的 是 ，! 


于 volatile 不 能 保 记 


代替 synchronized《〈 同 步 的 )。 此 外 ， 使 用 volatile 会 阻止 编译 器 对 代码 的 优化 ， 
程序 的 执行 效率 。 所 以 ， 除 非 迫 不 得 已 ， 和 否则 ， 能 不 使 用 volatile， 则 尽 直 


真题 


操作 的 原子 性 ， 


因此 ， 一 般 情 况 下 ， Volatile 不 能 


| 此 可 见 ， 


人 


全 。 所 以 ， 选 项 B 正确 
所 以 ， 本 题 的 答案 为 B。 
8. 答案 : A、C。 
分 析 : 本 题 考察 的 是 对 Collection 
Collection 类 结构 如 图 26 所 示 。 


o 


类 结 


关键 字 volatile 的 主要 目的 是 防 
存 里 读 取 ， 而 不 是 从 缓存 里 读 取 ， 这 样 能 保证 读 取 到 最 新 被 修改 的 数据 ， 而 不 能 


因此 ， 会 降低 

不 要 使 用 volatile 。 

上 编译 器 做 优化 ， 每 次 读 取 数 据 的 时 候 都 从 内 
保证 线程 安 


构 的 型 


E 解 。 


Dictionary 


de ee 
: CEE : es He PE : AbstractMap : 
: Listlterator :produces: .: List : Set : a 
ns 和 i 7 5 A 

a Noe dl 

: AbstractCollection i Ce i i 

: 一 AbstractSet : : SortedSet : 


LinkedList 


LinkedHashSet 


图 26 ”Collection 类 结构 


从 图 26 可 知 ， 选 项 A 与 选项 C 正确 ， 
所 以 ， 本 题 的 答案 为 A、C。 
9. 答案 : B。 


选项 B (Set 是 接口 ) 与 选项 DD 错误 。 


分 析 : 本 题 考察 的 是 对 Java 浮 点 数 的 理解 。 


在 Java 语言 


PF， 默认 声明 的 小 数 是 double 类 型 的 ， 因 此 ， 在 对 float 类 型 的 变量 进行 初 


全 化 时 ， 需 要 对 其 进行 类 型 转换 。float 类 型 的 变量 有 两 种 初始 化 方法 : float 伍 1.0f 或 float 


人 =(float)1.0。 与 此 类 似 的 是 ， 在 Java 语言 ! 


为 long 的 变量 直接 赋值 时 ，int 类 型 的 值 无 法 表示 一 个 非常 大 


以 通过 如 下 的 方法 来 赋值 : long 二 26012402244L。 
本 题 中 ，0.6332 的 数据 类 型 是 double， 


所 以 ， 本 题 的 答案 为 了 B。 
10. 答案 : A。 


， 直 接 写 的 整 型 数字 是 int 类 型 的 ， 当 给 数据 类 型 
的 数字 ， 因 此 ， 在 赋值 的 时 候 可 


所 以 ， 选 项 B 正确 


o 
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分 析 : 本 题 考察 的 是 对 数据 溢出 的 理解 。 


假设 变量 i 为 nt 类 型 ， 当 i 为 int 能 表示 的 最 大 整数 时 ，it1 就 会 溢出 变 成 负数 ， 此 时 就 


满足 i+1<i。 如 下 例 所 示 : 


public class Test 

public static void main(String args[]) 

{ 
int i=Integer. MAX VALUE; 
if(i>i+1) 
{ 

System.out.println(" 存 在 "); 

} 


} 


程序 输出 结果 为 


存在 


所 以 ， 本 题 的 答案 为 A。 
11. 答案 : D。 


分 析 : 本 题 考察 的 是 Java 流 知识 。 


在 Java 语言 中 ， 输 入 和 输出 都 被 称 为 抽象 的 流 ， 流 可 以 看 作 是 一 组 有 序 的 字 节 集合 ， 即 


数据 在 两 个 设备 之 间 的 传输 。 


流 的 本 质 是 数据 传输 ， 根据 处 理 数据 类 型 的 不 同 , 流 可 以 分 为 两 大 类 : 字 节 流 和 字符 流 。 
其 中 , 字 节 流 以 字 节 (8bit) 为 单位 , 包含 两 个 抽象 类 : InputStream〔 输 入 流 ) 和 OutputStream 
(输出 流 )。 字 符 流 以 字符 (16bit) 为 单位 ， 根 据 码 表 映 射 字 符 ， 一 次 可 以 读 多 个 字 节 ， 它 包 
含 两 个 抽象 类 : Reader( 输 入流) 和 Wiriter( 输 出 流 )。 其 中 ， 字 节 流 和 字符 流 最 主要 的 区 别 


为 : 字 节 流 在 处 理 输入 输出 的 时 候 不 会 用 到 缓存 ， 而 字符 流 用 到 了 缓存 。 


对 于 选项 A，Wiriter 代表 输出 流 。 所 以 ， 选 项 A 错误 。 


对 于 选项 B 和 选项 C，Stream 代表 的 是 字 节 流 。 所 以 ， 选 项 B 和 选项 C 错误 。 


对 于 选项 D，InputStreamReader 表示 的 是 输入 流 。 所 以 ， 选 项 D 正确 


所 以 ， 本 题 的 答案 为 D。 
12. 答案 : D。 


在 Java 语言 中 ， 接 口 能 且 只 能 被 public 和 abstract 修饰 符 来 修饰 


所 以 ， 本 题 的 答案 为 D。 
13. 答案 : A。 


分 析 : 本 题 考察 的 是 对 对 象 创 建 方法 的 理解 


6 所 以 ， 选项 D 正确 


o 


o 


在 Java 语言 中 ， 最 常用 的 创建 对 象 的 方法 为 使 用 new 创建 一 个 对 象 ， 这 种 方式 通过 调用 


类 的 构造 方法 来 完成 对 象 的 创建 ， 除 此 之 外 ， 还 有 如 下 几 种 创建 对 象 的 方法 : 
1) 调用 对 象 的 clone 方法 ， 需 要 以 下 几 个 步骤 才能 使 用 clone 方法 : 
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QD 实现 clone 的 类 首先 需要 继承 Cloneable 接口 。Cloneable 接口 实质 上 是 一 个 标识 接口 ， 
没有 任何 接口 方法 。 

@) 在 类 中 重 写 Object 类 中 的 clone 方法 。 

@@) 在 clone 方法 中 调用 super.clone()。 无 论 clone 类 的 继承 结构 是 什么 ，superclone0 都 会 
直接 或 间接 调用 java.lang.Object 类 的 clone() 方 法 。 

示例 代码 如 下 : 


class Obj implements Cloneable 


{ 


private int aInt=0; 
public ObjO 
{ 
System.out.println("construct"); 
} 
public int getAInt() 
{ 
return alnt; 
} 
public void setAInt(int int1) 
{ 
alnt = intl; 
} 
public void changeInt() 
{ 
this.alnt=1; 
} 
public Object clone() 
{ 
Object o=null; 
try 
{ 
0= (Obj)super.clone(); 
} 
catch (CloneNotSupportedException e) 
{ 


e.printStackTrace(); 


} 


return o; 


} 


public class Test 
{ 
public static void main(String[] args) 
{ 
Ob]j a=new Obj(); 
Ob]j b=(Obj)a.clone(); 
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b.changeInt(); 
System.out.println("a:"+a.getAInt()); 
System.out.println("b:"+b.getAInt()); 


} 


也 


程序 的 运行 结果 为 


construct 
a:0 
b:1 


从 以 上 程序 运行 结果 可 以 看 出 ， 在 调用 a.clone0 方 法 的 时 候 ， 
是 却 没有 调用 构造 方法 。 
2) 通过 反射 机 制 来 创建 对 象 ， 如 下 例 所 示 : 


系统 创建 了 新 的 对 象 ， 但 


class Person 
{ 
String name="Jack"; 
public Person() 
{ 
System.out.println("construct"); 
} 
public String toString() 
{ 
return name; 
} 
} 
public class Test 
{ 
public static void main(String[] args) 
{ 
Class classType; 
try 
{ 
classType = Class.forName("Person"); 
Person p = (Person)classType.newJInstance(); 
System.out.println(p); 
} 
catch (Exception e) 
{ 
e.printStackTrace(); 
} 
} 
} 
程序 的 运行 结果 为 
construct 
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Jack 


从 以 上 运行 结果 可 以 看 出 ， 这 种 方法 也 调用 了 构造 方法 。 
3) 通过 反 序 列 化 的 方式 创建 对 象 ， 示 例 代码 如 下 : 


import java.io.FileInputStream; 
import java.io.FileOutputStream; 
import java.io.ObjectInputStream; 
import java.io.ObjectOutputStream; 
import java.io.Serializable; 
public class People implements Serializable 
{ 

private String name; 

public People() { 

this.name = "lili"; 


System.out.println("construct"); 


} 
public String toString() 
{ 
return this.name; 
} 
public static void main(String[] args) 
{ 


People p= new People(); 
System.out.println(p); 
ObjectOutputStream oogs = null; 
ObjectInputStream ois = null; 


try 
{ 
FileOutputStream fos = new FileOutputStream("perple.out"); 
00s = new ObjectOutputStream(fos); 
O00s.writeObject(p); 
oos.close(); 
} 
catch (Exception ex) { 
} 
People pl; 
try 
{ 
FileInputStream fis = new FileInputStream("perple.out"); 
ois = new ObjectInputStream(fis); 
pl = (People) ois.readObject(); 
System.out.println(p); 
if(p!=p1) 
System.out.println("two different object"); 
ois.close(); 
} 
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catch (Exception ex) { 


} 


} 


程序 的 运行 结果 为 


construct 

lili 

lili 

two different object 


解密 使 用 同一 个 密 钥 ， 非 对 称 式 加 密 就 是 加 密 和 
常见 的 对 称 式 加 密 算法 有 DES 《效率 高 ， 适 用 了 


从 以 上 运行 结果 可 以 看 出 ， 用 反 序 列 化 的 方式 创建 对 象 也 不 需要 调用 构造 方法 。 


所 以 ， 本 题 的 答案 为 A。 
14. 答案 : A、B。 
分 析 : 本 题 考察 的 是 加 密 算法 知识 。 


加 密 算法 可 以 分 为 两 种 ， 对 称 式 加 密 算 法 和 非 对 称 式 加 密 算法 。 对 称 式 加 密 就 是 加 密 和 


( 速 


和 
于 o 


默认 的 大 小 为 10， 在 后 面 使 月 


解密 所 使 用 的 不 是 同一 个 密 钥 。 


F 加 密 大 量 数据 )、3DES (采用 三 个 不 同 
加 密 ， 更 加 安全 )、RC2 和 RC4( 采 用 变 长 的 密 钥 ， 比 DES 效率 更 高 ) 以 及 AES 


度 快 ， 安 全 级 别 高 ) 等 ， 常 见 的 非 对 称 式 加 密 算 法 有 RSA、DSA【〔 数 字 签 名 算法 ) 及 ECC 


所 以 ， 选 项 A 与 选项 B 正确 。 
所 以 ， 本 题 的 答案 为 A、B。 

15. 答案 : A。 

分 析 : 本 题 考察 的 是 ArrayList 知识 。 


在 Java 语言 中 , 创建 ArrayList 对 和 象 的 时 候 可 以 不 指定 其 空间 大 小 ,在 这 种 情况 下 ,列表 


小 的 1.5 倍 。 
对 于 本 题 而 言 ， 在 初始 化 ArrayList 对 象 的 时 候 ， 显 式 地 指定 了 列表 的 大 小 为 20， 因 此 ， 


创建 出 来 的 列表 对 象 的 长 度 为 20， 在 这 个 过 程 


AI 


列表 在 扣 


傅 。 


区 ( 


所 以 ， 本 题 的 答案 为 A。 
16. 答案 : B。 


分 析 : 本 题 考察 的 是 对 流 包装 类 的 理解 。 
本 题 中 ,选项 A、 选 项 C 及 选项 DD 的 方法 写法 都 是 正确 的 ， 只 有 选项 B 的 方法 写法 不 正 


BufferedReader 是 Reader 的 一 个 子 类 ， 


读 取信 息 。 它 有 以 下 两 个 构造 函数 : 


1) BufferedReader (Reader in) 
2) BufferedReader(Reader in, int sz) 
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不 需要 扩 


如 果 把 题目 改 成 ArrayList list = new ArrayList()， 接 着 向 列表 里 扣 
入 第 11 条 记录 的 时 候 就 需要 扩展 一 次 。 


它 具 有 


的 作用 ， 避 免 了 频繁 地 从 物理 


/sz 是 指定 缓冲 区 的 大 小 


的 过 程 中 ， 如 果 发 现 列 表 的 大 小 不 够 用 ， 此 时 会 扩充 为 原来 大 


展 ， 即 扩展 次 数 为 0。 所 以 ， 选 项 


入 20 条 记录 ， 那 么 这 个 


设备 中 


| 此 可 见 ，BufferedReader 类 只 能 用 来 包装 Reader 类 或 其 子 类 。 因 此 ， 选 项 B 错误 。 


真题 详解 篇 


所 以 ， 本 题 的 答案 为 了 B。 

17. 答案 : B。 

分 析 : 本 题 考察 的 是 对 Java 基本 概念 的 理解 。 

在 Java 语言 中 ， 给 任何 对 象 赋值 为 null 都 是 合法 的 ， 因 为 null 可 以 被 强制 转换 为 任意 类 
型 的 对 象 ， 转 换 的 结果 还 是 null， 所 以 无 法 调用 对 象 的 方法 ， 但 是 却 可 以 调用 类 的 方法 
为 类 的 方法 是 不 依赖 于 对 象 而 存在 的 )。 

对 于 本 题 而 言 ，((Test) nulD) 可 以 把 null 转换 为 Test 类 型 的 对 象 ( 转 换 后 的 值 为 null)， 
于 hello 是 一 个 静态 方法 ， 因 此 ， 可 以 直接 调用 ， 输 出 结果 为 “hello”。 所 以 ， 选 项 B 正确 。 

所 以 ， 本 题 的 答案 为 B。 

18. 答案 : A。 

分 析 : 本题 考察 的 是 对 Java 捕获 异常 处 理 流程 的 理解 。 

在 Java 语言 中 ， 通 常 是 通过 try/catch 来 处 理 异常 的 ， 当 try 块 中 的 代码 出 现 异 常 后 ， 将 
会 匹配 catch 块 中 的 异常 ， 一 旦 匹配 成 功 ， 就 会 执行 catch 块 的 代码 进行 异常 处 理 。 

通常 ， 可 以 有 多 个 catch 语句 ， 也 就 是 说 ， 可 以 用 来 匹配 多 个 异常 ， 但 是 当 每 次 执行 的 时 
候 ， 最 多 只 会 匹配 一 个 异常 ， 每 当 匹 配 到 其 中 一 个 异常 后 ， 仅 执行 catch 块 中 匹配 上 的 那个 异 
常 ， 而 其 他 的 catch 块 将 不 会 被 执行 。 对 于 本 题 而 言 ， 如 果 抛 出 IOException 异常 后 ， 
FileNotFoundException 不 是 IOException 的 父 类 ， 接 着 异常 IOException 匹配 成 功 ， 进 入 异常 
处 理 块 输出 IOException， 然 后 程序 运行 结束 。 所 以 ， 选 项 A 正确 。 

所 以 ， 本 题 的 答案 为 A。 

19. 答案 : A。 

分 析 : 本 题 考察 的 是 字符 串 知识 。 

本 题 中 , 由 于 “3” 是 字符 串 , 因此 , 在 执行 "3"+4 的 过 程 中, 首先 把 4 转换 为 字符 串 “4”， 
然后 再 执行 字符 串 拼接 ， 结 果 为 “34” 因此， 程序 的 输出 结果 为 34。 所 以 ， 选 项 A 正确 。 

如 果 把 题目 改 成 System.out.println(3+4)， 由 于 + 操作 两 边 的 变量 都 是 int 类 型 ， 因 此 ， 此 
时 会 先 执行 加 操作 ， 结 果 为 7， 然 后 把 7 输出 。 

所 以 ， 本 题 的 答案 为 A。 

20. 答案 : C。 

分 析 : 本 题 考 察 的 是 对 Java 变量 初始 化 的 理解 。 

在 Java 语言 中 ， 任 何 变量 只 有 被 初始 化 后 才能 被 使 用 ， 如 果 没 有 被 初始 化 就 直接 使 用 ， 
是 无 法 编译 通过 的 。 本 题 中 ， 由 于 String s 没有 初始 化 ， 所 以 ， 代 码 不 能 编译 通过 。 所 以 ， 选 


Ea 


a 


zs 


所 以 ， 本 题 的 答案 为 C 
21. 答案 : B 
22. 答案 : A 


分 析 : 本 题 考 察 的 是 对 Java 流 的 理解 。 

FileInputStream 类 的 skip(long n) 方 法 的 功能 为 从 输入 流 中 跳 过 并 丢弃 n 个 字 节 的 数据 。 
对 于 选项 A， 先 执行 in.skip(9) 语 句 ， 跳 过 了 9 个 字 节 ， 接 下 来 读 取 到 的 一 定 是 第 10 个 字 
因此 ， 选 项 A 正确 。 同 理 ， 选 项 B 读 取 到 的 是 第 一 个 字 节 ， 选 项 C 读 取 到 的 是 第 11 个 
。 因 此 ， 选 项 B 与 选项 C 错误 。 


娄 寸 
或 
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对 于 选项 D，RandomAccessFile 类 并 没有 提供 只 有 一 个 参数 的 构造 方法 ， 它 的 构造 方法 


RandomAccessFile(File file, String mode) 
RandomAccessFile(String name, String mode) 


因此 ， 选 项 DD 错误 。 

所 以 ， 本 题 的 答案 为 A。 

23. 答案 : C。 

24. 答案 : D。 

分 析 : 本 题 考察 的 是 对 switch/case 运行 机 制 的 理解 。 

在 使 用 switch 时 ， 需 要 特别 注意 的 问题 是 ， 必 须 在 case 语句 结尾 添加 break 语句 。 因 为 
一 旦 通过 switch 语句 确定 了 入 口 点 ， 就 会 顺序 执行 后 面 的 代码 ， 直 到 过 到 关键 字 break。 否 则 ， 
会 执行 满足 这 个 case 之 后 的 其 他 case 语句 而 不 管 case 是 否 匹 配 ， 直 到 switch 结束 或 者 过 到 
break 为 止 。 如 果 在 switch 中 省 略 了 break 语句 , 那么 匹配 的 case 值 后 的 所 有 情况 (包括 default 
情况 ) 都 会 被 执行 。 

对 于 本 题 而 言 ， 当 输入 为 2 时 ， 会 匹配 case 2 的 情况 ， 此 时 会 执行 result = result +i*2， 
执行 结束 后 ，result 的 值 为 4， 由 于 没有 break 语句 跳出 switch 语句 ， 此 时 会 继续 执行 case 3 
中 的 代码 result = result +i*3 (result=4，i=2)， 执 行 完 result=10。 所 以 ， 选 项 DD 正确 。 

所 以 ， 本 题 的 答案 为 D。 

25. 答案 : A。 

分 析 : 本 题 考察 的 是 对 抽象 类 使 用 的 理解 。 

如 果 一 个 类 中 包含 抽象 方法 ， 那 么 这 个 类 就 是 抽象 类 。 在 Java 语言 中 ， 可 以 通过 把 类 或 
者 类 中 的 某 些 方法 声明 为 abstract 来 表示 一 个 类 是 抽象 类 。 

只 要 包含 一 个 抽象 方法 的 类 就 必须 被 声明 为 抽象 类 ， 抽 和 象 类 可 以 声明 方法 的 存在 而 不 去 
实现 它 ， 被 声明 为 抽象 的 方法 不 能 包含 方法 体 。 

对 于 选项 A， 定 义 了 一 个 方法 ， 这 个 方法 与 已 有 的 方法 有 不 同 的 参数 ， 可 以 作为 方法 的 
重 载 。 因 此 ， 选 项 A 正确 。 

对 于 选项 B， 任 何 执行 语句 必须 存在 于 一 个 代码 块 中 (方法 体 、 静 态 快 等 ;， 不 能 单独 存 
在 于 类 的 定义 中 。 因 此 ， 选 项 B 错误 。 

对 于 选项 C， 这 个 方法 与 已 知 的 方法 名 以 及 参数 相同 ， 因 此 ， 会 导致 编译 错误 。 因 为 无 
法 通过 返回 值 来 进行 重 载 。 此 外 ， 这 个 方法 没有 被 声明 为 abstract， 说 明 它 不 是 抽象 方法 ， 必 
须 有 方法 体 ， 但 选项 C 的 写法 也 没有 方法 体 。 因 此 ， 选 项 C 错误 。 

对 于 选项 D， 使 用 关键 字 abstract 修饰 的 方法 为 抽象 方法 ， 不 能 有 方法 体 ， 也 就 是 说 不 能 
有 位。 因此 ， 选 项 DD 错误 。 

所 以 ， 本 题 的 答案 为 A。 

26. 答案 : B。 

27. 答案 D。 

分 析 : 本 题 考 察 的 是 对 构造 方法 调用 顺序 的 理解 。 

本 题 中 , 在 调用 new Child("e") 时 ， 由 于 Child 继承 了 People, 但 是 Child 类 的 构造 方法 中 
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没有 显 式 地 调用 父 类 的 构造 方法 ， 因 此 ， 编 译 器 会 默认 调用 父 类 的 无 参数 的 构造 方法 。 因 此 ， 


首先 会 输出 1， 接 着 才 会 调用 Child 类 的 构造 方法 输出 3， 


People(name + ":F") 语 句 会 调用 People 类 的 有 参数 的 构造 方法 ， 输 出 2。 所以， 选项 D 正确 。 


所 以 ， 本 题 的 答案 为 D。 


二 、 简 答题 


真题 详解 篇 


在 Child 的 构造 方法 中 ， 调 用 new 


1. 答案 : 本 题 考察 的 是 Java 初始 化 顺序 ， 答 案 如 下 : 


static Base 
static Sub 

I'm Base class 
Base 

Im Sub class 
Sub 


三 、 系 统 设计 题 
答案 : 在 解答 本 题 前 ， 首 先 需要 弄 明白 一 个 概念 ， 那 
的 解释 ，tinyurl 是 第 一 个 专门 提供 缩 略 网 址 服务 的 网 站 ， 
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就 是 什么 是 tinyurl? 根据 百度 百科 
它 提供 一 个 短 网 址 并 转向 指定 的 长 


网 址 ， 网 站 最 初 是 由 Kevin Gilbertson 所 开发 ， 并 于 2002 年 1 月 开始 提供 服务 。 


弄 懂 了 这 个 意思 ， 那 么 题目 的 问题 自然 就 容易 理解 了 
1. 需要 将 url 转 为 tinyurl 编码 ， 可 以 采用 以 下 思路 : 


首先 将 url 转换 成 int 值 ， 然 后 ， 采 


用 字母 与 数字 的 组 合 进行 编码 ， 由 于 a~z (26 个 不 同 字 符 )、A~Z (26 个 不 同 字符 ) 及 0~9 
(10 个 不 同 字 符 ) 有 62 个 字符 ， 因 此 ， 可 以 通过 把 int 值 再 转换 为 62 进 制 的 编码 。 如 果 


为 62^6=56800235584。 在 实际 使 用 时 ， 可 以 根据 实际 url 
为 62 进 制 的 编码 是 比较 容易 的 , 因此 , 本 题 的 难点 是 怎样 


用 1n 位 字符 进行 编码 ， 可 以 表示 的 url 数 为 62^n。 假 如 采用 6 位 字符 编码 ， 可 以 表示 的 url 数 


的 数量 选用 合适 的 n。 把 int 值 转换 
把 url 转换 为 int 值 , 可 以 采用 Hash 


函数 〔 必 须要 处 理 Hash 冲突 的 情况 )。 比 较 简单 的 方法 是 采用 数据 库 主键 自 增 的 原理 ， 每 有 


url 需要 被 转换 的 时 候 ， 通 过 数据 库 主键 自 增 的 方式 产生 url 对 应 的 主键 〈 自 增 主键 为 整 型 变 
量 )， 每 个 整 型 变量 对 应 这 一 个 62 进 制 的 tinyurl。 数 据 库 表 中 其 中 一 列 是 主键 〈 自 增 主键 )， 


男 外 一 列 存储 url。 


2. 当 用 户 输入 一 个 已 经 转换 过 的 url 时 ， 如 何 快速 定位 到 已 经 生成 了 的 tinyurl 呢 ? 方法 
也 很 简单 ， 这 个 转换 过 的 url 一 定 是 62 进 制 的 字符 串 ， 首 先 ， 把 这 个 62 进 制 的 字符 串 转 换 成 


对 应 的 整数 值 ， 这 个 值 就 对 应 数据 库 里 的 一 个 主键 ， 然 后 


通过 这 个 主键 就 可 以 很 容易 地 在 数 


据 库 表 中 找到 对 应 的 url。 当 然 ， 在 这 个 过 程 中 ， 也 可 以 使 用 Redis (Redis 是 一 个 开源 的 使 用 


ANSIC 语言 编写 、 文 持 网 络 、 可 基于 内 存 亦 可 持久 化 的 日 


志 型 、Key-Value 数据 库 )、Leveldb 


(Leveldb 是 一 个 Google 实现 的 非常 高 效 的 Key-Value 数据 库 ) 等 Key-Value 数据 库 进 一 步 加 


快 查询 过 程 。 


3. 如 果 数 据 为 10 亿 条 ， 需 要 10 个 tinyurl 服务 器 ， 怎 么 设计 呢 ? 方法 也 不 难 ， 如 果 
输入 一 个 转换 过 的 url， 则 采用 主键 的 方式 ， 主 键 是 自 增 的 ， 因 此 ， 也 是 均匀 分 布 的 ， 故 可 以 
通过 轮 询 的 方式 把 请 求 均匀 地 分 布 在 10 个 服务 器 上 把 主键 为 n 的 url 分 配 到 主机 编号 为 


n%10 的 服务 器 上 去 执行 ) 在 10 个 服务 器 之 前 加 上 负载 均衡 ， 根 据 进 制 压缩 的 结果 将 请 求 转 


发 到 相应 的 服务 器 ， 每 个 服务 器 中 有 独立 cache， 后 端 公 月 


日 数据库。 
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ia 是 [ 脸 东 知 名 互联 网 金融 企业 软件 工程 师 笔试 题 


一 、 不 定 项 选择 题 

1. 答案 : B。 

分 析 : 本 题 考 察 的 是 对 重 载 与 覆盖 的 理解 。 

public static void main(String[] args) 为 Java 程序 的 入 口 方法 ，JVM 在 运行 程序 时 ， 会 首先 


查找 main 方法 。 需 要 注意 的 是 ， 只 有 与 文件 名 相同 的 类 中 的 main 方法 才能 作为 整个 程序 的 
入 口 方法 。 


个 普 


普通 的 方法 ， 而 不 是 程序 的 入 口 方法 。 所 以 ， 在 运行 的 时 候 ， 由 于 JVM 找 不 到 程序 的 入 
方法 ， 程 序 会 运行 错误 。 所 以 ， 选 项 B 正确 。 


对 于 本 题 而 言 ， 文 件 Testjava 中 没有 Test 类 ,， 因 此， 这 个 类 里 面 的 main 方法 被 看 作 是 一 


如 果 本 题 把 文件 名 由 Testjava 改 为 Bjava， 那 么 此 时 程序 的 运行 结果 就 为 1。 

所 以 ， 本 题 的 答案 为 了 B。 

2. 答案 : B。 

分 析 : 本 题 考察 的 是 对 数组 的 理解 。 

在 Java 语言 中 ， 数 组 下 标 是 从 0 开始 的 ， 所 以 ， 一 个 大 小 为 n 的 数组 ， 它 的 有 效 下 标 是 


0~~n-1。 如 果 下 标 不 在 这 个 范围 内 ， 束 会 发 生 错 误 。 


本 题 中 ， 首 先 申 请 了 一 个 长 度 为 5 的 数组 ， 数 组 的 下 标 为 0 一 4。 当 使 用 arr[5] 访 问 数 组 


元 素 的 时 候 ， 由 于 访问 地 址 不 在 数组 能 够 访问 的 合法 地 址 范围 内 ， 此 时 就 发 生 了 数组 越界 ， 
会 抛 出 java.lang.ArrayIndexOutOfBoundsException 异常 ， 导 致 程序 出 现 运 行 错 误 。 所 以 ， 选 项 
B 正确 。 


Ls 


所 以 ， 本 题 的 答案 为 了 B。 

3. 答案 A、B、C。 

参见 真题 3 中 问答 题 4。 

4. 答案 : D。 

分 析 : 本 题 考 察 的 是 对 Thread 类 的 理解 。 

在 Java 语言 中 ， 可 以 采用 以 下 两 种 方法 来 创建 线程 : 继承 Thread 类 与 实现 Runnable 接 
其 中 ， 在 使 用 Runnable 接口 时 ， 需 要 建立 一 个 Thread 实例 。 所 以 ， 无 论 是 通过 Thread 


类 创建 线程 还 是 通过 Runnable 接口 创建 线程 ， 都 必须 建立 Thread 类 或 它 的 子 类 的 实例 。 


Thread 类 提供 了 一 个 start0 方 法 , 该 方法 的 功能 是 让 这 个 线程 开始 执行 ， 当 这 个 线程 开始 


执行 后 ，JVM 将 会 调用 这 个 线程 的 run(0 方 法 来 执行 这 个 线程 的 任务 。 在 实现 多 线程 时 ， 在 继 
承 了 Thread 类 后 必须 实现 run0 方 法 ， 也 就 是 说 ， 线 程 的 核心 多 辑 都 存在 于 run(0 方 法 中 ， 这 
个 方法 被 start0 方 法 调用 来 实现 多 线程 的 功能 ， 如 果 直 接 调用 run0 方 法 ， 就 与 调用 普通 的 方 


法 类 似 。 


对 于 本 题 而 言 ，Test 类 继承 了 Thread 类 ， 但 是 没有 重 写 Thread 类 的 run0 方 法 ， 因 此 ， 


b.run0 实 际 上 调用 的 是 Thread 类 的 run0) 方 法 ， 而 Thread 类 的 run(0) 方 法 的 方法 体 为 空 ， 因 此 ， 
这 个 程序 能 编译 通过 ， 但 是 却 没 有 输出 结果 。 所 以 ， 选 项 D 正确 。 


所 以 ， 本 题 的 答案 为 D。 
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5. 答案 : C。 

分 析 : 本 题 考 察 的 是 对 Java 关键 字 的 理解 。 

对 于 选项 A， 被 static 修饰 的 方法 是 指 这 个 方法 是 类 的 方法 。 因 此 ， 选 项 B 错误 。 
对 于 选项 B， 被 final 修饰 的 方法 是 不 允许 子 类 重 写 的 。 因 此 ， 选 项 A 错误 。 

对 于 选项 C， 被 abstract 修饰 的 方法 是 没有 方法 体 的 ， 也 就 是 说 没有 任何 逻辑 。 这 个 方法 
需要 子 类 来 重 写 。 因 此 ， 选 项 C 正确 。 
对 于 选项 D，void 一 般 用 来 作为 返回 值 使 用 ， 表 示 没 有 返回 值 。 因 此 ， 选 项 DD 错误 。 

所 以 ， 本 题 的 答案 为 C。 

6. 答案 : D。 

分 析 : 本 题 考 察 的 是 对 构造 方法 的 理解 。 

一 般 而 言 ， 构 造 方法 都 是 被 public 修饰 的 ， 这 样 这 个 构造 方法 对 所 有 的 类 都 是 可 见 的 。 
当 构 造 方法 被 protected 修饰 时 ， 只 有 当前 类 、 当 前 包 和 子 类 可 见 。 当 构造 方法 被 private 修饰 
时 ， 只 对 本 类 可 见 ， 常 被 用 来 实现 单 例 模式 。 

对 于 本 题 而 言 ， 定 义 了 一 个 protected 的 构造 方法 ， 由 于 main 方法 在 这 个 类 内 部 ， 因 此 ， 
这 个 构造 方法 对 main 方法 是 可 见 的 ， 所 以 ， 会 调用 这 个 构造 方法 输出 0~9。 因 此 ， 选 项 D 
正 胡 


所 以 ， 本 题 的 答案 为 D。 

7. 答案 : B、C。 

分 析 : 本 题 考察 的 是 对 数组 和 String 类 的 理解 。 

String 类 的 length0 方 法 可 以 用 来 求解 字符 串 的 长 度 ， 数 组 的 length 属性 用 来 求解 数组 的 
大 小 ， 如 下 例 所 示 : 


public class Test 


{ 
public static void main(String argv[]) 
{ 
int a[]={1}; 
System.out.println(a.length); 
String s="Hello"; 
System.out.println(s.length()); 
} 
} 
程序 的 运行 结果 为 
1 
5 


因此 ， 选 项 B 与 选项 C 正确 。 

所 以 ， 本 题 的 答案 为 B、C。 

8. 答案 : C。 

分 析 : 本 题 考察 的 是 对 String 与 StringBuffer 的 理解 。 

String 和 StringBuffer 都 是 类 ， 在 方法 调用 的 时 候 ， 二 者 传递 的 都 是 引用 值 〈 可 以 理解 为 
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传递 的 是 它们 的 地 址 )。 对 于 String 而 言 ， 由 于 String 是 不 可 变量 (一 旦 赋值 后 ， 它 的 内 容 就 
不 能 被 修改 了 )， 可 能 有 人 会 有 疑问 ， 既 然 String 是 不 可 变 类 ， 为 什么 还 可 以 写 出 如 下 代码 来 


修改 String 类 型 的 值 呢 ? 


public class Test 


{ 


{ 


s+=" world"; 


} 
} 


String s="Hello' 


public static void main(String[] args) 


he 
和 


System.out.println(s); 


程序 的 运行 结果 为 


Hello world 


表面 上 看 ， 好 像 是 修改 String 类 型 对 象 s 的 值 。 其 实 不 是 ，String s="Hello" 语 句 声明 了 一 


个 可 以 指向 String 类 型 对 象 的 引 
语句 s+="world" 并 没有 改变 s 所 


]， 这 个 引用 的 名 字 为 s， 它 指向 了 一 个 字符 串 


常量 “Hello”。 


指向 的 对 象 ( 由 于 “Hello” 是 String 类 型 的 对 象 ， 而 String 


又 是 不 可 变量 )， 当 这 名 代码 执行 后 ，s 指向 了 另外 一 个 String 类 型 的 对 象 ， 该 对 象 的 内 容 为 


“Hello world”。 原来 的 那个 字符 串 常量 “Hello” 还 存在 于 内 存 中 


PF， 并 没有 被 改变 。 


从 本 质 上 来 讲 ， 引 用 传递 是 通过 值 传递 实现 的 (传递 了 引用 的 值 ， 或 者 可 以 理解 为 传递 


的 是 对 象 地 址 的 值 )， 对 于 本 题 而 言 ， 在 调用 stringReplace 方法 时 ， 首 先 把 实 参 textString 的 


值 复制 给 形 参 text (textString 是 字符 串 “ab” 的 引用 ， 或 者 可 以 理 
在 方法 stringReplace 内 执行 语句 text=textt"e" 的 时 候 ， 相 当 于 创建 了 一 个 新 


“abc”， 然后 text 指向 这 个 字符 串 对 象 ， 这 并 没有 改变 实 参 textString 的 值 ， 因 


解 为 是 “ab” 的 地 址 )， 当 


的 字符 串 对 象 
此 ， 在 调用 结 


束 后 , textString 指向 的 字符 串 的 值 还 是 “ab”。 StringBuffer 不 是 不 可 变量 , 在 调 


方法 的 时 候 ， 先 把 实 参 的 值 ttxtBuffer 赋值 给 形 参 text〈 字 符 串 “ab” 的 引用 ， 


地 址 )， 在 调用 text.append("c") 的 


jbufferReplace 


或 可 以 理解 为 


时 候 , 会 直接 对 text 指向 的 字符 串 后 面 拼接 一 个 字符 串 “c”， 


由 于 text 与 textBuffer 指向 同一 个 字符 串 ， 因 此 ， 这 个 对 形 参 的 修改 也 会 影响 到 实 参 的 值 ， 调 


用 结束 后 textBuffer 的 值 为 “abc”。 所 以 ， 选 项 C 正确 。 


所 以 ， 本 题 的 答案 为 C。 
9. 答案 A、D、BE、F。 


分 析 : 本 题 考察 的 是 对 String 比较 的 理解 。 
1) 判 等 运算 符 “ 一 ”用 来 比较 两 个 变量 的 值 是 否 相 等 ， 也 就 是 用 于 比较 变量 所 对 应 的 内 


存 中 所 存储 的 数值 是 否 相 同 ， 要 比较 两 个 基本 类 型 的 数据 或 两 个 引用 变量 是 否 相 等 ， 只 能 使 


用 判 等 运算 符 “==”。 
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具体 而 言 ， 如 果 两 个 变量 都 是 基本 数据 类 型 ， 可 以 直接 使 用 判 等 运算 符 “==” 来 比较 其 
对 应 的 值 是 否 相 等 。 如 果 一 个 变量 指向 的 数据 是 对 象 (3 引 月 
在 ， 对 象 本 身 占 用 一 块 内 存 〈 推 内 存 )， 变 量 〈 对 象 的 引用 ) 也 占用 一 块 内 存 。 例 如 ， 对 于 赋 
值 语句 String s = new String("Hello")， 变 量 s 占 月 


昌 类 型 )， 那 么 ， 此 时 涉及 了 两 块 内 


一 块 存储 空间 ， 而 “Hello” 则 存储 在 男 外 一 


真题 详解 篇 


块 存储 空间 里 ， 此 时 ， 变 量 s 所 对 应 的 内 存 中 存储 的 数值 就 是 对 象 “Hello” 占 用 的 那 块 内 存 
的 首 地 址 。 对 于 指向 对 象 类 型 的 变量 ， 如 果 要 比较 两 个 变量 是 否 指向 同一 个 对 象 ， 即 要 看 这 
两 个 变量 所 对 应 的 内 存 中 的 数值 是 否 相 等 (这 两 个 对 和 象 是 否 指 癌 同一 块 存储 空间 )， 这 时 候 就 
可 以 用 “==” 运 算 符 进行 比较 。 但是, 如 果 要 比较 这 两 个 对 象 的 内 容 是 否 相等 , 那么 使 用 “==” 
运算 符 就 无 法 实现 了 。 

2) equals 是 Object 类 提供 的 方法 之 一 ， 每 一 个 Java 类 都 继承 自 Object 类 ， 所 以 ， 每 一 
个 对 象 都 具有 equals 这 个 方法 。Object 类 中 定义 的 equals(Object) 方法 是 直接 使 用 “==” 运 算 
符 比 较 的 两 个 对 象 ， 所 以 ， 在 没有 履 盖 equals(Objecb) 方法 的 情况 下 ，equals(Objecb 与 “一 ” 
运算 符 一 样 ， 比 较 的 是 引用 。 
与 “天 ”运算 符 相 比 ，equals(Object) 方法 的 特殊 之 处 就 在 于 它 可 以 被 覆盖 ， 所 以 ， 可 以 
通过 履 善 的 方法 让 它 不 是 比较 引用 而 是 比较 数据 内 容 。 例 如 String 类 的 equals 方法 是 用 于 比 
较 两 个 独立 对 象 的 内 容 是 否 相 同 。 例 如 ， 对 于 下 面 的 代码 ; 

String sl=new String("Hello"); 
String s2=new String("Hello"); 

两 条 new 语句 创建 了 两 个 对 象 ， 然 后 用 s1、s2 这 两 个 变量 分 别 指 向 了 一 个 对 象 ， 这 是 两 
个 不 同 的 对 象 ， 它 们 的 首 地 址 是 不 同 的 。 即 字符 串 a 和 字符 串 b 中 存储 的 数值 是 不 相同 的 ， 
所 以 ， 表 达 式 a==b 将 返回 false， 而 这 两 个 对 象 中 的 内 容 是 相同 的 ， 所 以 ， 表 达 式 a.equals(b) 
将 返回 true。 

根据 以 上 分 析 可 知 ， 选 项 D、 选 项 E 及 选项 F 是 正确 的 ， 因 为 这 些 字符 串 都 有 着 相同 的 
内 容 。 

在 Java 语言 中 ， 字 符 串 起 着 非常 重要 的 作用 ， 字 符 串 的 声明 与 初始 化 主要 有 如 下 两 种 情况 : 

1) 对 于 String sl=new String("abc") 语 句 与 String s2=new String("abc") 语 句 ， 存在 两 个 引用 
对 象 s1、s2， 两 个 内 容 相同 的 字符 串 对 象 “abc” 它们 在 内 存 中 的 地 址 是 不 同 的 。 只 要 使 用 
到 new， 总 会 生成 新 的 对 象 。 

2) 对 于 String sl = "abc" 语 名 与 String s2 = "abc" 语 句 ， 在 JVM 中 存在 着 一 个 字符 串 池 ， 
其 中 保存 着 很 多 String 对 象 ， 并 且 这 些 对 象 可 以 被 共享 使 用 ，s1、s2 引用 的 是 同一 个 常量 池 
中 的 对 象 。 由 于 String 的 实现 采用 了 Flyweight 〈 享 元 ) 的 设计 模式 ， 当 创建 一 个 字符 串 常量 
的 时 候 , 例如 String s = "abc", 会 首先 在 字符 串 常量 池 中 碍 找 是 否 已 经 有 相同 的 字符 串 被 定义 ， 
它 的 判断 依据 是 String 类 equals(Object obj) 方 法 的 返回 值 。 如 果 已 经 定义 ， 则 直接 获取 对 其 的 
引用 ， 此 时 不 需要 创建 新 的 对 象 ， 如 果 没 有 定义 ， 则 首先 创建 这 个 对 象 ， 然 后 把 它 加 入 到 字 
符 串 池 中 ， 再 将 它 的 引用 返回 。 由 于 String 是 不 可 变 类 ， 一 旦 创建 好 了 就 不 能 被 修改 ， 因 此 ， 
String 对 象 可 以 被 共享 而 且 不 会 导致 程序 的 混乱 。 

从 以 上 分 析 可 知 ， 对 于 本 题 而 言 ， 字 符 串 a 和 b 都 指向 常量 池 的 字符 串 ， 因 此 ， 有 着 相同 
的 地 址 ， 因 此 ， 表 达 式 a==b 的 返回 值 为 tue， 字 符 串 c 和 d 分 别 指向 两 个 在 堆 空 间 上 申请 的 字 
符 串 ， 显 然 , 字符 串 c、d 和 a 有 着 不 同 的 地 址 ， 因此, 表达 式 a==c 和 c 一 d 的 返回 值 都 为 false。 

所 以 ， 本 题 的 答案 为 A、D、E、F。 

10. 答案 : B。 

分 析 : 本 题 考察 的 是 对 Java 基本 语法 的 理解 。 


串 
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在 Java 语言 中 ， 变 量 在 使 用 前 必须 初始 化 ， 否 则 将 无 法 编译 通过 。 上 述 代码 定义 了 变量 
i， 但 是 在 没有 初始 化 的 情况 下 就 使 用 了 ， 因 此 会 产生 编译 错误 。 所 以 ， 选 项 B 正确 。 

所 以 ， 本 题 的 答案 为 B。 

11. 答案 A、C。 

参见 真题 5 中 单 选 题 19。 

12. 答案 : A。 

分 析 : 本 题 考察 的 是 Java 语言 基础 知识 。 

本 题 中 ， 当 这 个 程序 所 在 的 Java 文件 名 为 B.java 的 时 候 ， 运 行 结果 为 AB， 否 则 ， 编 译 
能 通过 ， 运 行 时 会 出 错 ， 因 为 找 不 到 程序 的 入 口 方法 main。 所 以 ， 选 项 A 正确 。 

所 以 ， 本 题 的 答案 为 A。 

13. 答案 : C。 

分 析 : 本 题 考 察 的 是 对 static 的 理解 。 

被 关键 字 static 修饰 的 属性 表示 这 个 属性 是 类 的 属性 ， 是 所 有 对 象 共享 的 ， 这 个 类 中 定义 
了 一 个 类 的 属性 1〈 这 个 类 的 属性 会 被 默认 初始 化 为 0)。 在 main 方法 中 ， 首 先 实 例 化 了 一 个 
对 象 ， 并 调用 了 test 方法 ， 当 调用 结束 后 ， 变 量 i 的 值 变 为 1， 接 着 在 System.out.println 语句 
内 又 创建 了 一 个 对 象 , 并 调用 了 test 方法 , 由 于 i 是 所 有 对 象 共 享 的 , 因此, 等 到 调用 结束 后 ， 
i 的 值 由 1 变 成 2， 所 以 ， 返 回 值 为 2， 因 此 ， 输 出 结果 为 2。 所 以 ， 选 项 C 正确 。 

所 以 ， 本 题 的 答案 为 C。 

14. 答案 : C。 

分 析 : 本 题 考 察 的 是 对 关键 字 super 的 理解 。 

在 Java 语言 中 , 子 类 可 以 通过 super 关键 字 来 显 式 地 调用 父 类 的 构造 函数 , 示例 代码 如 下 : 


class B 
{ 
public BO 
{ 
System.out.println("construct B"); 
} 
} 
class C extends B 
{ 
public C() 
{ 


super(); 
} 
} 
public class Test { 
public static void main(String args[]) 
{ 
new C(); 
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程序 输出 结果 为 
construct B 


super 为 Java 语言 的 关键 字 ， 自 定义 的 方法 名 不 能 是 super。 所 以 ， 选 项 C 正确 。 

所 以 ， 本 题 的 答案 为 C。 

15. 答案 : A、B。 

分 析 : 本 题 考 察 的 是 对 Thread 类 的 理解 。 

对 于 选项 A，start 方法 是 Thread 类 中 比较 重要 的 方法 , JVM 通过 调用 这 个 方法 启动 一 个 
线程 。 所 以 ， 选 项 A 正确 。 

对 于 选项 B，sleep 是 使 线程 暂停 执行 一 段 时 间 的 方法 。 所 以 ， 选 项 B 正确 。 

对 于 选项 C 和 选项 D，wait 和 notify 都 是 从 Object 类 继承 的 方法 。 所 以 ， 选 项 C 和 选项 
D 错误 。 

所 以 ， 本 题 的 答案 为 A、B。 

16. 答案 : B、C、D。 

分 析 : 本 题 考 察 的 是 对 Java 基本 概念 的 理解 。 

对 于 选项 A， 当 一 个 类 作为 内 部 类 使 用 的 时 候 ， 可 以 被 private 修饰 。 因 此 , 选项 A 错误 。 

对 于 选项 B， 接 口中 定义 的 成 员 变量 默认 为 public static final， 只 能 够 有 静态 的 、 不 能 被 
修改 的 数据 成 员 ， 而 且 ， 必 须 给 其 赋 初 值 。 因 此 ， 选 项 B 正确 。 

对 于 选项 C， 内 部 类 可 以 被 protected 修饰 。 因 此 ， 选 项 C 正确 。 

对 于 选项 D， 由 于 接口 中 的 方法 都 没有 具体 的 实现 ， 因 此 是 不 能 被 实例 化 的 ， 只 有 当 一 
个 类 实现 了 接口 中 的 所 有 方法 后 ， 这 个 类 才能 被 实例 化 。 因 此 ， 选 项 D 正确 。 

所 以 ， 本 题 的 答案 为 B、C、D。 

17. 答案 ， A、C、 DD。 

分 析 : 本 题 考察 的 是 对 synchronized 关键 字 的 理解 。 

关键 字 synchronized 的 主要 功能 是 保证 任何 时 候 都 只 有 一 个 线程 访问 一 个 方法 或 对 象 。 
所 以 ， 选 项 B 正确 ， 选 项 A、 选 项 C 和 选项 DD 错误 。 

所 以 ， 本 题 的 答案 为 A、C、D。 

18. 答案 : D。 

分 析 : 本 题 考察 的 是 对 抽象 方法 的 理解 。 

在 Java 语言 中 ， 被 abstract 修饰 的 方法 为 抽象 方法 ， 这 种 方法 是 没有 方法 体 的 (也 就 是 
说 ， 没 有 大 插 号 f}; 一旦 有 大 括号 分， 就 说 明 这 个 方法 有 方法 体 )。 因 此 ， 选 项 B 和 选项 C 
昔 误 ， 选 项 D 正确 。 

对 于 选项 A，abstract 只 能 用 来 修饰 方法 和 类 ， 不 能 修饰 属性 。 因 此 ， 选 项 A 错误 。 

所 以 ， 本 题 的 答案 为 D。 

19. 答案 , B、D。 

分 析 : 本 题 考察 的 是 对 TCP 和 UDP 的 理解 。 

传输 层 协议 主要 有 TCP 协议 与 UDP 协议 。UDP (User Datagram Protocol， 用 户 数 据 报 协 
议 ) 提供 无 连接 的 通信 ， 不 能 保证 数据 包 被 发 送 到 目标 地 址 ， 典 型 的 即时 传输 少量 数据 的 应 
用 程序 通常 使 用 UDP; 而 TCP〈《Transmission Control Protocol， 传 输 控 制 协议 ) 是 一 种 面向 连 
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许可 的 应 用 程序 提供 连接 定向 和 可 靠 的 通信 。 


TCP 


完毕 之 后 再 


通话 ， 通 记 
发 短信 ， 
答 也 不 知 
TCP 与 UDP 都 是 常用 的 通信 方式 ， 在 特定 


道 ， 对 方 对 


和 UDP 的 区 别 主 要 表现 为 以 下 几 个 方面 : 
1) TCP 是 面向 连接 的 传输 控制 协议 ， 而 UDP 提供 的 是 无 连接 的 数据 报 服务 。 


2) TCP 具有 高 可 靠 性 ， 确 保 传输 数据 的 正确 性 ， 不 出 现 丢 失 或 乱 序 ，UD 


连接 就 像 打 电 话 ， 用 户 拨打 特定 的 电话 号 码 ， 对 方 在 线 并 接 起 电话 ， 
引 挂 断 ， 整 个 过 程 是 一 个 相互 联系 、 缺 一 不 可 的 过 程 。 而 UDP 连接 就 像 
用 户 短信 发 送 给 对 方 ， 对 方 有 没有 收 到 信息 ， 发 送 者 根本 不 知道 ， 而 且 对 方 是 否 回 
言 恩 发 送 者 发 送 消 息 也 是 一 样 。 


的 通信 协议 ， 它 为 传输 大 量 数据 或 为 需要 接收 数据 


然后 双方 进行 


的 条 们 


F 下 发 挥 不 同 的 作用 。 有 具体 而 言 ，TCP 


在 传输 数据 


前 不 建立 连接 ， 不 对 数据 报 进行 检查 与 修改 ， 无 须 等 待 对 方 的 应 答 ， 所 以 会 出 现 分 组 丢失 、 


重复 和 乱 序 ， 


UDP 协议 各 有 所 长 、 各 有 所 短 ， 适 月 
但 在 某 些 环境 下 ， 需 要 可 
提 及 卫 协议 ，IP 协议 是 一 种 网 络 


地 芭 


类 


被 实例 化 ， 然 后 去 调 月 


应 用 程序 需要 负责 传输 可 靠 性 方面 的 所 有 工作 。 


3) TCP 对 系统 资源 要 求 较 多 ，UDP 对 系统 资源 要 求 较 少 。 

4) UDP 具有 较 好 的 实时 性 ， 工 作 效 率 较 TCP 协议 高 。 

因此 网 络 开 销 也 小 。 

既然 UDP 协议 比 TCP 协议 的 效率 更 高 ， 为 什么 TCP 还 能 够 保留 呢 ? 其 实 ，TCP 协议 和 


5) UDP 段 结构 比 TCP 的 段 结构 简单 ， 


= 
和 


所 以 ， 本 题 的 答案 为 B、D。 
20. 答案 : A、B。 
分 析 : 本 题 考察 的 是 对 抽象 类 的 理解 。 


靠 的 连接 ， 此 时 采用 TCP | 


于 不 同 要 求 的 通信 环境 。 在 有 些 环境 下 ,UDP 确实 高 效 ， 


协议 则 更 好 。 在 提 及 TCP 的 时 候 ， 也 一 般 
层 协 议 ， 它 规定 每 个 互联 网 上 的 计算 机 都 有 一 个 唯一 的 他 
上 ， 这 样 数据 包 就 可 以 通过 路 由 器 的 转发 到 达 指 定 的 计算 机 ， 但 卫 协议 并 不 保证 数据 传输 
的 可 靠 性 。 所 以 ， 选 项 B 与 选项 D 正确 。 


在 Java 语言 中 ， 可 以 通过 把 类 或 者 类 中 的 某 些 方法 声明 为 abstract 来 表示 一 个 类 是 抽象 


对 于 选项 B， 


必须 被 声明 为 抽象 类 ， 


。 抽 象 类 是 不 能 被 实例 化 的 。 显 然 ， 选 项 A 正确 ， 选 项 D 错误 。 
只 要 类 中 有 抽象 方法 ， 这 个 类 前 


否则 ， 这 个 类 就 能 


抽象 方法 ， 这 显然 是 不 合理 


对 于 选项 C， 从 抽象 类 的 定义 可 以 看 出 ， 抽 象 类 没有 要 求 所 有 的 方法 是 抽象 的 ， 


不 能 
象 的 时 
静态 方法 调用 非 静态 方法 时 ， 就 会 昌 


所 以 ， 本 题 的 答案 为 A、B。 
21. 答案 : A。 


的 。 


因此 ， 选 项 B 正确 。 


的 方法 也 可 以 有 方法 体 ， 只 要 这 个 方法 没 被 abstract 修饰 。 


分 析 : 本 题 考察 的 是 对 静态 方法 的 理解 。 


在 


Java 语言 中 ， 被 声明 为 static 的 方法 为 静态 方法 ， 静 态 方法 内 部 只 能 调用 静态 方法 ， 


调用 非 静态 方法 。 原 


内 是 莉 


所 以 ， 本 题 的 答案 为 A。 
22. 答案 : C。 
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恬 就 可 以 调用 ;而 非 静 态 方法 是 对 象 的 方法 ， 只 有 对 象 被 实例 化 后 才 存在 。 
上 现 编译 错误 。 所 以 ， 选 项 A 正确 。 


| 象 类 


因此 ， 选 项 C 错误 。 


态 方法 是 类 的 方法 ， 是 不 依赖 于 对 象 而 存在 的 ， 在 不 创建 对 


因此 ， 当 
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分 析 : 本 题 考 察 的 是 对 序列 化 的 理解 。 

所 有 要 实现 序列 化 的 类 都 必须 实现 Serializable 接口 ，Serializable 接口 位 于 java.lang 包 中 ， 
里 面 没有 包含 任何 方法 。 使 用 一 个 输出 流 (例如 FileOutputStream ) 来 构造 一 个 ObjectOutputStream 
(对 象 流 ) 对 象 ， 紧 接着 ， 使 用 该 对 象 的 writeObject (Object obj) 方法 就 可 以 将 obj 对 象 写 出 
〈 即 保存 其 状态 )， 要 恢复 的 时 候 可 以 使 用 其 对 应 的 输入 流 。 所 以 ， 选 项 C 正确 。 

所 以 ， 本 题 的 答案 为 C。 

23. 答案 : DD。 

参见 真题 7 中 简 答题 11 。 

24. 答案 : A。 

分 析 : 本 题 考察 的 是 对 集合 框架 的 理解 。 

Collection 是 一 个 集合 接口 。 它 提供 了 对 集合 对 象 进行 基本 操作 的 通用 接口 方法 。 实 现 该 
接口 的 类 主要 有 List 和 Set, 该 接口 的 设计 目标 是 为 各 种 具体 的 集合 提供 最 大 化 的 统一 的 操作 


方式 。 类 图 如 图 27 所 示 : 
用 : ee : 
: Iterator 近 : Droduces :Droduces : Map x 
ne 从 和 入 A ee 


Pt 


TT ee。 ooesposo。 


i 人 Re We 
ee a 
: Abatractcollection a A 


uc======--=-=-Kc-------------- 


LinkedHashSet 


LinkedList 


图 27 Collection 类 图 


由 此 可 见 ， 选 项 A 正确 ， 选 项 C 和 选项 DD 错误 。 
Collections 是 针对 集合 类 的 一 个 包装 类 ， 它 提供 一 系列 静态 方法 实现 对 各 种 集合 的 搜索 、 
排序 以 及 线程 安全 化 等 操作 ， 其 中 的 大 多 数 方法 都 是 用 来 处 理 线性 表 。Collections 类 不 能 实 
例 化 ， 如 同一 个 工具 类 ， 服 务 于 Collection 框架 。 因 此 ，Collections 不 是 一 个 集合 框架 类 。 因 
此 ， 选 项 D 错误 。 

所 以 ， 本 题 的 答案 为 A。 

25. 答案 : D。 

分 析 : 本 题 考 察 的 是 对 关键 字 final 的 理解 。 

在 Java 语言 中 ， 被 final 关键 字 修 饰 的 类 是 不 能 被 继承 的 。 所 以 ， 选 项 D 正确 。 
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所 以 ， 本 题 的 答案 为 D。 

26. 答案 : A。 

分 析 : 本 题 考 察 的 是 对 线程 的 理解 。 
Thread 类 提供 了 一 个 start 方法 ， 这 个 方法 的 功能 是 让 这 个 线程 开始 执行 ， 开 始 执行 后 ， 


JVM 将 会 调 


被 start 方法 i 


这 个 线程 的 run 方法 来 执行 这 个 线程 的 任务 。 在 实现 多 线程 的 时 候 ， 在 继承 了 
Thread 方法 后 必须 实现 run 方法 ,也 就 是 说 , 线程 的 核心 次 辑 都 存在 于 


run 方法 中 。 这 个 方法 


用 来 实现 多 线程 的 功能 ， 如 果 直 接 调用 run 方法 就 与 调用 普通 的 方法 类 似 。 所 
以 ， 选 项 A 正确 ， 选 项 B 错误 。 


对 于 选项 C， 在 Java 语言 中 ， 线 程 是 没有 begin 方法 的 。 所 以 ， 选 项 C 错误 。 
对 于 选项 D，notify 方法 是 用 来 唤醒 一 个 线程 的 ， 而 不 是 启动 一 个 线程 。 所 以 ， 选 项 D 


普 误 。 


所 以 ， 本 题 的 答案 为 A。 
27. 答案 : C。 
分 析 : 本 题 考 察 的 是 对 接口 的 理解 。 


需要 一 个 关键 字 implements， 多 个 接口 用 逗号 隔 开 即 可 。 因 此 ， 选 项 C 
对 于 选项 A， 只 有 类 才能 实现 接口 ， 而 接口 是 不 能 实现 接口 的 。 因 此 ， 选 项 A 错误 。 
对 于 选项 B， 接 口 只 能 继承 接口 ， 而 不 能 继承 类 。 因 此 ， 选 项 B 错误 。 
所 以 ， 本 题 的 答案 为 C。 
28. 答案 : C。 


分 析 : 本 题 考察 的 是 对 数组 声明 方式 的 理 


ay 
-Fd 
o 


在 Java 语言 中 ， 一 维 数组 的 声明 方式 为 

type arrayName[] 或 type[] arrayName 

其 中 ，type 既 可 以 是 基本 的 数据 类 型 ， 也 可 以 是 类 ，arrayName 表示 数组 的 名 字 ，[] 用 来 
表示 这 个 变量 的 类 型 为 一 维 数组 。 与 C/C++ 语言 不 同 的 是 ， 在 Java 语言 中 ， 数 组 被 创建 后 会 


根据 数组 存放 的 数据 类 型 初始 化 成 对 应 的 初始 值 


只 有 类 才能 实现 接口 ， 而 实现 接口 的 关键 字 为 implements， 当 实现 多 个 接口 的 时 候 ， 只 


正确 ， 选 项 D 错误 。 


《例如 int 类 型 会 初始 化 为 0， 对 象 会 初始 化 


为 null)。 另 外 一 个 不 同 之 处 是 ，Java 数组 在 定义 的 时 候 ， 并 不 会 给 数组 元 素 分 配 存 储 空 间 ， 


因此 , 口中 不 需要 指定 数组 的 长 度 。 对 于 使 用 上 面 方式 定义 的 数组 在 使 朋 
配 空间 ， 分 配方 法 如 下 : 


arrayName = new type[arraySize]; VarraySize 表示 数组 的 长 度 


在 完成 数组 的 声明 后 ， 需 要 对 其 进行 初始 化 ， 下 面 介绍 两 种 初始 化 方法 : 


1) int[] a= new int[$]; 


昌 的 时 候 还 必须 为 之 分 


// 动 态 创建 了 一 个 包含 5 个 整 型 值 的 数组 ， 默 认 初 始 化 为 0 


2) int[] a={1,2,3,4,5}; /声明 一 个 数组 类 型 变量 并 初始 化 


当然 ， 在 使 月 


的 时 候 也 可 以 把 数组 的 声明 和 初始 化 分 开 来 写 ， 例 如 : 


1) int[] a; /声明 一 个 数组 类 型 的 对 象 a 

a=new int[5]; /给 数组 a 申请 可 以 存放 5 个 int 类 型 大 小 的 空间 ， 数 组 元 素 的 默认 值 为 0 
2) int[] a; /声明 一 个 数组 类 型 的 对 象 a 

a=new int[] {1,2,3,4,5}; // 给 数组 申请 存储 空间 ， 并 初始 化 为 默认 值 
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| 此 可 见 ， 只 有 选项 C 满足 题 意 要求 。 所 以 ， 选 项 C 正确 

所 以 ， 本 题 的 答案 为 C。 

29. 答案 : A、B。 

分 析 : 本 题 考 察 的 是 对 Java 多 线程 实现 的 理解 。 

Java 多 线程 实现 一 般 有 两 种 方法 : 继承 Thread 类 与 实现 Runnable 接口 。 所 以 ， 选 项 A 
与 选项 B 正确 。 

所 以 ， 本 题 的 答案 为 A、B。 

30. 答案 : D。 

分 析 : 本 题 考 察 的 是 对 集合 排序 使 用 方法 的 理解 。 

在 Java 语言 中 ， 如 果 要 对 集合 对 象 或 数组 对 象 进 行 排序 ， 就 需要 实现 Comparator 接口 的 
compare 方法 ， 从 而 实现 自 定 义 类 的 比较 。 下 面 给 出 一 个 例子 来 对 自 定 义 的 类 排序 〈 通 过 年 龄 
大 小 按 行 排序 )， 实 现代 码 如 下 : 


import java.util.ArrayList; 
import java.util.Collections; 
import java.util.Comparator; 
import java.util.List; 
class Student 
{ 
private String name; 
private int age; 
public Student(String name,int age) 
{ 
this.name=name; 
this.age=age; 
} 
public String getName() 
{ 
return name; 
} 
public void setName(String name) 
{ 
this.name = name; 
} 
public int getAge() 
{ 
return age; 
} 
public void setAge(int age) 
{ 
this.age = age; 


} 


} 


class StudentComparator implements Comparator<Student> 
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{ 
(QOverride 
public int compare(Student s1, Student s2) 
{ 
if(sl.getAge()>s2.getAge()) 
return 1; 
else 
return -1; 
} 
} 
public class Example 
{ 
public static void main(String[] args) 
{ 
List<Student> stus=new ArrayList<Student>(); 
stus.add(new Student("name1",5)); 
stus.add(new Student("name2",6)); 
stus.add(new Student("name3",4)); 
Collections.sort(stus, new StudentComparator()); 
for(Student stu:stus) 
{ 
System.out.printin(stu.getName()); 
} 
} 
} 
程序 的 运行 结果 为 
name3 
namel 
name2 


本 题 中 ， 对 于 选项 A， 当 一 个 类 需要 实现 克隆 功能 时 ， 需 要 实现 Cloneable 接口 。 所 以 ， 
选项 A 错误 。 

对 于 选项 B， 当 需要 实现 一 个 线程 时 可 以 继承 Thread 类 。 所 以 ， 选 项 B 错误 。 

对 于 选项 C，Runnable 是 用 来 实现 多 线程 的 接口 。 所 以 ， 选 项 C 错误 。 

对 于 选项 D，Serializable 是 用 来 实现 序列 化 的 接口 。 在 对 Student 的 对 象 进行 排序 时 ， 使 
用 的 是 自 定义 的 比较 方法 。 所 以 ， 选 项 DD 正确 。 

所 以 ， 本 题 的 答案 为 D。 

31. 答案 : C、D、E。 

分 析 : 本 题 考察 的 是 对 履 盖 〈Override) 的 理解 。 

在 Java 语言 中 ， 黎 盖 是 实现 多 态 的 关键 技术 ， 在 子 类 中 定义 与 父 类 相同 的 方法 ， 同 时 有 
自己 不 同 于 父 类 的 实现 ， 在 使 用 的 时 候 可 以 用 父 类 的 引用 执行 不 同 的 子 类 ， 从 而 在 运行 时 决 
定 调用 哪个 子 类 的 方法 。 多 态 的 实现 有 如 下 几 点 要 求 ， 
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1 ) 子 类 方法 与 父 类 名 字 相 同 。 

2) 子 类 方法 与 父 类 有 相同 的 参数 列表 〈 相 同 的 参数 个 数 与 类 型 )， 如 果 参 数列 表 不 一 样 ， 
则 不 是 罗 盖 ， 而 是 重 载 。 

3) 当 方 法 名 与 参数 列表 相同 的 时 候 ， 返 回 值 必须 相同 。 


4) 子 类 覆盖 的 方法 的 可 见 性 必须 大 于 或 等 于 父 类 方法 的 可 见 性 。 
对 于 本 题 而 言 : 
对 于 选项 A， 在 Java 语言 中 ， 默 认 的 作用 域 为 private， 由 于 父 类 的 方法 为 protected， 如 


果 定 义 为 private 会 导致 方法 有 更 低 的 可 见 性 。 所 以 ， 选 项 A 错误 。 

对 于 选项 B， 方 法 名 与 参数 列表 与 父 类 相同 ， 但 是 返回 值 不 同 。 所 以 ， 选 项 B 错误 。 

对 于 选项 C， 定 义 的 方法 与 父 类 虽然 同名 ， 但 是 有 不 同 的 参数 列表 ， 因 此 ， 这 相当 于 从 
父 类 继承 了 一 个 方法 getNum， 然 后 通过 定义 另外 一 个 参数 列表 不 同 的 方法 重 载 了 getNum 方 
法 。 所 以 ， 选 项 C 正确 。 

对 于 选项 D, 在 Java 语言 中 ,是 区 分 大 小 写 的 , 因此 , 选项 DD 宪 盖 定义 了 一 个 新 的 方法 ， 
与 父 类 的 方法 没关系 。 所 以 ， 选 项 D 正确 。 

对 于 选项 了 E， 满 足 Override 的 要 求 ， 因 此 ， 履 盖 了 父 类 的 方法 。 所 以 ， 选 项 E 正确 。 

所 以 ， 本 题 的 答案 为 C、D、E。 

32. 答案 : A。 

分 析 : 本 题 考察 的 是 对 异常 的 理解 。 

于 文件 不 存在 , 因此 , 在 调用 new FileOutputStream("d:/abc.txt"”) 时 , 会 抛 出 FileNotFoundException 
异常 , 这 个 异常 是 Exception 的 子 类 , 所 以 , 能 匹配 Exception 从 而 执行 catch 块 的 代码 输出 “ 文 
件 没有 发 现 !”。 所 以 ， 选 项 A 正确 。 

所 以 ， 本 题 的 答案 为 A。 

33. 答案 : A、C。 

参见 24 题 的 类 网 。 

34. 答案 : A、C。 

分 析 : 本 题 考 察 的 是 对 Map 的 理解 。 

Java 为 数据 结构 中 的 映射 定义 了 一 个 接口 java.util.Map， 它 有 三 个 实现 类 : HashMap、 
Hashtable 和 TreeMap。Map 是 用 来 存储 键 - 值 对 的 数据 结构 , 在 数组 中 通过 数组 下 标 来 对 其 内 
容 进行 索引 ， 而 在 Map 中 ， 则 是 通过 对 象 来 进行 索引 ， 用 来 索引 的 对 象 叫 作 key， 其 对 应 的 
对 象 叫 作 value。 

HashMap 是 一 个 最 常用 的 Map， 它 根据 键 的 HashCode 值 存储 数据 ， 根 据 键 可 以 直接 获 
取 它 的 值 ， 具 有 很 快 的 访问 速度 。 由 于 HashMap 与 Hashtable 都 采用 了 Hash 方法 进行 索引 ， 
因此 ， 两 者 具有 许多 相似 之 处 ， 当 然 ， 它 们 也 存在 各 自 的 不 同 ， 有 具体 而 言 ， 两 者 的 区 别 如 下 : 

1) HashMap 是 Hashtable 的 轻 量 级 实现 〈 非 线程 安全 的 实现 )， 它 们 都 实现 了 Map 接口 ， 
主要 区 别 在 于 HashMap 允许 空 (null) 键 值 (key) 〈 但 需要 注意 ， 最 多 只 允许 一 条 记录 的 键 
为 null， 不 允许 多 条 记录 的 值 为 null)， 而 HashTable 不 允许 。 

2) HashMap 把 Hashtable 的 contains 方法 去 挤 了 ， 改 成 containsvalue 和 containsKey。 因 
为 contains 方法 容易 引起 误解 。Hashtable 继承 自 Dictionary 类 ,而 HashMap 是 Javal.2 引进 的 
Map interface 〈 接 口 ) 的 一 个 实现 。 
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3) Hashtable 的 方法 是 线程 安全 的 ， 而 HashMap 由 于 不 支持 线程 的 同步 ， 所 以 ， 它 不 是 
线程 安全 的 。 在 多 个 线程 访问 Hashtable 时 , 不 需要 开发 人 员 对 它 进行 同步 , 而 对 于 HashMap， 
开发 人 员 必 须 提 供 额 外 的 同步 机 制 。 所以， 效率 上 HashMap 可 能 高 于 Hashtable。 

4) Hashtable 使 用 Enumeration，HashMap 使 用 Iterator。 

5) Hashtable 和 HashMap 采用 的 hash/rehash 算法 几乎 都 一 样 ， 所 以 ， 性 能 不 会 有 很 大 的 

6) Hashtable 中 Hash 数组 默认 大 小 是 11， 增 加 的 方式 是 old*2+1。 在 HashMap 中 ，Hash 
数组 的 默认 大 小 是 16， 而 且 一 定 是 2 的 指数 。 

7) Hash 值 的 使 用 不 同 ，Hashtable 直接 使 用 对 象 的 HashCode。 

所 以 ， 选 项 A 与 选项 C 正确 。 

所 以 ， 本 题 的 答案 为 A、C。 

35. 答案 : A、B。 

分 析 : 本 题 考 察 的 是 对 构造 方法 的 理解 。 

构造 方法 是 一 个 类 特有 的 方法 ， 每 个 类 都 有 自己 的 构造 方法 ， 它 是 不 能 被 继承 的 ， 因 此 ， 
构造 方法 不 能 被 重 写 ， 但是， 可 以 定义 多 个 参数 不 同 的 构造 方法 ， 即 可 以 重 载 构造 方法 。 因 
此 ， 选 项 A 和 选项 B 正确 ， 选 项 C 错误 。 

对 于 选项 DD, 构造 方法 可 以 定义 为 private, 在 单 例 模 式 中 , 通过 把 构造 方法 定义 为 private 
可 以 阻止 显 式 地 实例 化 对 象 ， 因 此 ， 选 项 D 错误 。 

所 以 ， 本 题 的 答案 为 A、B。 

36. 答案 :， A。 

参见 真题 7 中 简 答题 6 中 知识 点 的 介绍 。 

37. 答案 : C。 

分 析 : 本 题 考察 的 是 对 异常 处 理 的 理解 。 

本 题 中 ， 首 先 定义 了 长 度 为 5 的 数组 (数组 下 标 范 围 为 0~4)， 在 接 下 来 访问 数组 的 时 
候 ， 当 遍历 到 下 标 为 5 的 数组 元 素 时 , 会 抛 出 ArrayIndexOutOfBoundsException 异常 ， 从 而 执 
行 catch 块 的 代码 输出 : 数组 下 标 越界 ， 接 着 会 运行 finally 块 的 代码 输出 : 程序 结束 。 所 以 ， 
选项 C 正确 。 

所 以 ， 本 题 的 答案 为 C。 

38. 答案 : A、C。 

分 析 : 本 题 考 察 的 是 对 重 载 的 理解 。 

重 载 是 类 中 多 态 性 的 一 种 表现 ， 是 指 在 一 个 类 中 定义 了 多 个 同名 的 方法 ， 它 们 或 有 不 同 
的 参数 个 数 或 有 不 同 的 参数 类 型 。 在 使 用 重 载 时 ， 需 要 注意 以 下 几 点 ; 

1) 重 载 是 通过 不 同 的 方法 参数 来 区 分 的 ， 例 如 不 同 的 参数 个 数 、 不 同 的 参数 类 型 或 不 同 

的 参数 顺序 。 

2) 不 能 通过 方法 的 访问 权限 、 返 回 值 类 型 和 抛 出 的 异常 类 型 来 进行 重 载 。 

3) 对 于 继承 来 说 ， 如 果 基 类 方法 的 访问 权限 为 private， 那 么 就 不 能 在 派生 类 对 其 重 载 ， 
果 派 生 类 也 定义 了 一 个 同名 的 方法 ， 这 只 是 一 个 新 的 方法 ， 不 会 达到 重 载 的 效果 。 

下 面 通过 一 个 例子 来 详细 说 明 这 一 点 : 


娄 


I 
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class A 
{ 
public void f() 


{ 


System.out.printin(this.getClass().getName()); 
1 
} 


} 


class B extends A 
{ 
public void fint i) 
{ 
System.out.printin(this.getClass().getName()+); 
} 
} 


public class Test 
{ 
public static void main(String[] args) 
{ 
B b= new B(); 
/类 B 从 类 A 中 继承 了 方法 10 
b.f0); 
// 类 B 中 又 定义 了 另外 一 个 带 参 数 的 方法 ftint i) 
// 在 类 中 存在 两 个 方法 名 为 f 的 方法 
b.f(4); 
} 


程序 的 运行 结果 为 


从 上 面 例子 可 以 看 出 ， 虽 然 类 B 没有 定义 方法 们 ， 但 它 从 父 类 A 中 继承 了 方法 fj。 而 
且 在 类 B 中 又 定义 了 一 个 方法 flint i， 由 此 可 以 看 出 ， 类 B 中 其 实 有 两 个 名 字 为 工 的 方法 ， 
由 于 它们 的 参数 不 同 ， 由 此 构成 了 重 载 。 因 此 ， 在 这 种 继承 的 情况 下 ， 从 本 质 上 来 讲 ， 重 载 
还 是 发 生 在 一 个 类 中 。 如 果 把 类 B 中 定义 的 方法 改 成 public void ff， 在 这 种 情况 下 ， 这 个 方 
法 与 父 类 A 中 的 方法 名 相同 ， 参 数 相同 ， 返 回 值 相同 ， 此 时 就 构成 了 宪 六 (Override)， 而 且 
它们 发 生 在 父 类 与 子 类 之 间 。 

对 于 本 题 而 言 ， 显 然 ， 选 项 A 和 选项 C 满足 重 载 的 要 求 。 对 于 其 他 选项 定义 的 方法 都 有 

返回 值 ， 而 题目 中 的 方法 却 没有 返回 值 〈 构 造 方 法 不 能 有 返回 值 )， 因 此 ， 不 是 重 载 〈 不 能 
返回 值 来 区 分 重 载 )， 因 为 重 载 的 方法 必须 要 有 相同 的 返回 值 。 所 以 ， 选 项 C 正确 。 

所 以 ， 本 题 的 答案 为 A、C。 

39. 答案 : C、D、E。 

分 析 : 本 题 考察 的 是 对 Class 的 理解 。 
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在 Java 语言 中 ， 主 要 有 如 下 几 种 方法 可 以 用 来 获取 Class 对 象 : 

1) 调用 对 象 的 getClass 方法 ， 选 项 DD 就 是 采用 这 各 方法。 所以， 选项 D 正确 。 

2) 调用 Class.forName0 方 法 ， 这 个 方法 的 参数 为 类 的 全 名 《〈 包 名 .类 名 )， 选 项 E 就 是 使 
用 这 种 方法 。 所 以 ， 选 项 E 正确 。 

3) 使 用 .class 语法 来 获得 Class 对 象 ， 具 体 而 言 ， 就 是 调用 类 的 .class 来 获取 Class 对 象 ， 
选项 C 就 是 采用 这 种 方法 。 所 以 ， 选 项 C 正确 。 

所 以 ， 本 题 的 答案 为 C、D、E。 

40. 答案 : B、E。 

分 析 : 本 题 考 察 的 是 对 接口 的 理解 。 

接口 中 所 有 的 成 员 方 法 都 是 public、abstract 的 ， 而 且 只 能 被 这 两 个 关键 字 修饰 。 当 然 也 
可 以 不 加 修饰 。 所 以 ， 选 项 B、 选 项 E 正确 。 

所 以 ， 本 题 的 答案 为 B、E。 

二 、 简 答题 

1. 答案 : 它们 的 主要 区 别 是 fail-safe 允许 在 遍历 的 过 程 中 对 容器 中 的 数据 进行 修改 ， 而 
fail-fast 则 不 允许 。 下 面 分 别 介绍 这 两 种 迭代 器 的 工作 原理 。 

fail-fast: 直接 在 容器 上 进行 遍历 , 在 遍历 的 过 程 中 , 一 旦 发 现 容器 中 的 数据 被 修改 了 ( 添 
加 元 素 、 删 除 元 素 或 修改 元 素 )， 会 立刻 抛 出 ConcurrentModificationException 异 常 导 致 壳 历 失 
败 。 常 见 的 使 用 fail-fast 方式 的 容器 有 HashMap 和 ArrayList 等 。 

fail-safe: 这 种 遍历 基于 容器 的 一 个 克隆 。 因 此 ， 对 容器 中 内 容 的 修改 不 影响 遍历 。 常 见 
的 使 用 fail-safe 方式 遍历 的 容器 有 ConcurrentHashMap 和 CopyOnWriteArrayList。 

2. 答案 : 在 Java 语言 中 ，String 是 不 可 变 类 ， 它 被 存储 在 常量 字符 串 池 中 ， 从 而 实现 了 
字符 串 的 共享 ， 减 少 了 内 存 的 开 文 。 正 因为 如 此 ， 一 旦 一 个 String 类 型 的 字符 串 被 创建 出 来 ， 
这 个 字符 串 就 会 存在 于 常量 池 中 直到 被 垃圾 回收 器 回收 为 止 。 因 此 ， 即 使 这 个 字符 串 《 比 如 
密码 ) 不 再 被 使 用 ， 它 仍然 会 在 内 存 中 存在 一 段 时 间 (只 有 垃圾 回收 器 才 会 回收 这 块 内 容 ， 
蛙 序 员 没 有 办 法 直接 回收 字符 串 )。 此 时 有 权限 访问 memory dump〔《 存 储 器 转 储 ) 的 程序 都 可 
能 会 访问 到 这 个 字符 串 ， 从 而 把 敏感 的 数据 暴露 出 去 ， 这 是 一 个 非常 大 的 安全 隐患 。 如 果 使 
用 字符 数组 ， 一 旦 程序 不 再 使 用 这 个 数据 ， 程 序 员 就 可 以 把 字符 数组 的 内 容 设置 为 空 ， 此 时 
这 个 数据 在 内 存 中 就 不 在 在 了 。 从 以 上 分 析 可 以 看 出 ， 与 使 用 String 相 比 ， 使 用 字符 数组 ， 
蛙 序 员 对 数据 的 生命 周期 有 更 好 的 控制 ， 从 而 可 以 增强 安全 性 。 

3. 答案 : 可 以 通过 设置 线程 的 UncaughtExceptionHandler〔 异 常 捕获 处 理 方法 ) 来 捕获 
线程 抛 出 的 异常 ， 如 下 例 所 示 : 


class MyThread extends Thread 


~h 


| 


{ 
public void run() 
{ 
System.out.println("thread will throw exception"); 
throw new RuntimeException("My own exception from thread"); 
} 
} 
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public class Test 


f 
1 


// 处 理 异 常 的 handler 
private static Thread.UncaughtExceptionHandler handler = 


new Thread.UncaughtExceptionHandler() 


{ 
public void uncaughtException(Thread th, Throwable ex) 
{ 
System.out.println("Uncaught exception: " + ex); 
} 
上 
public static void main(String[] args) 
{ 


Thread.UncaughtExceptionHandler handler = 
new Thread.UncaughtExceptionHandler() { 
public void uncaughtException( Thread th, Throwable ex) { 
System.out.println("Uncaught exception: " + ex); 


和 

Thread myThread=new MyThread(); 

/设置 捕获 异常 的 handler 
myThread.setUncaughtExceptionHandler(handlem); 
myThread.start(; 


1 
3 
程序 的 运行 结果 六 


thread will throw exception 
Uncaught exception: java.lang.RuntimeException: My own exception from thread 


4. 答案 : 这 道 题 要 求 存储 三 类 信息 : 用 户 信 息 、 关 系 信息 以 及 用 户 之 间 的 关系 信息 。 涉 
及 的 表 见 表 11 一 表 13。 

(1) 用 户 表 : 存储 用 户 基本 信息 。 

create table user info(user id int primary key, user name varchar(30) ,user age int); (这 个 3 


键 可 以 使 用 数据 库 自 增 的 方式 来 实现 ， 不 同 的 数据 库 定义 的 方法 有 所 不 同 ) 


| 


表 11 用 户 表 
user id User_name user age 
1 James 18 
2 Ross 25 
3 Jack 50 


(2) 用 户 关系 定义 表 : 主要 存储 用 户 之 间 所 有 可 能 的 关系 。 


create table relation define(relation ld int primary key, relation name varchar2(32)); 
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表 12 用 户 关系 定义 表 


relation id relation define 
1 同事 
2 父子 
3 朋友 


(3) 用 户 关系 信 ， 


昌 表 : 存储 用 户 关 系 信息 。 


create table user relation(user id int, rel_user id int,relation id int ); 


表 13 用 户 关系 信息 表 
user id rel_user id relation 
1 2 1 
2 3 2 
1 3 3 


表 13 中 数据 表示 1 (James) 和 2 (Ross) 是 同事 关系 。3 (Jack) 和 2 (Ross) 是 父子 关 


。1 (James) 和 3 (Jack) 是 朋友 关系 。 
示例 : 查询 用 户 1 的 社会 关系 


select a.user name,b.relation name from user info a, relation define b, 


(select user_id,relation id from user relation where rel_ user id =1 union Select rel user id as 


user id,relation id from 


user relation where user id =1)c 


where a.user_ id=c.user id and b.relation id=c.relation id 


运算 结果 见 表 14。 


表 14 查询 用 户 1 社会 关系 的 结果 


user name 


relati 


on 


Ross 


同事 


和 


Jack 


5. 答案 : 
个 程序 分 成 若干 个 段 (Segment〉 进行 存 


朋友 


族 ， 每 个 段 都 是 一 个 


A 


段 页 式 虚 拟 存储 管理 是 基本 分 段 存储 管理 
段 式 和 页 式 


川 


每 一 个 段 赋予 一 个 段 名 ， 页 间 不 要 求 连续 


页 式 存储 分 配 是 把 到 来 的 作业 分 成 相等 大 小 的 页 ， 段 式 存储 管理 是 指 把 一 


逻辑 实体 (Logical Entity )。 


方式 和 基本 分 页 存 


管理 的 优点 ， 即 先 将 用 户 程 序 分 成 若干 个 段 ， 再 把 每 个 段 分 成 若干 个 页 ， 


嵌 管 理 方式 原理 的 结合 , 兼 有 
并 为 
| 分 段 方法 分 配 管理 作业 ， 用 


(能 动态 连接 )， 用 


分 页 方法 分 配 管理 内 存 。 它 的 特点 是 空间 浪费 小 、 存 储 共享 容易 、 存 储 保护 容易 以 及 能 动 


态 连接 。 


段 页 式 


管理 采用 二 维 地 址 空间 ， 如 段 号 (S)、 页 号 (P)〉 和 页 内 单元 号 (D )。 系 统 建 两 


张 表 格 每 一 作业 一 张 段 表 ， 每 一 段 建立 一 张 页 表 ， 段 表 指 出 该 段 的 页 表 在 内 存 中 的 位 置 ， 地 
址 变换 机 构 类 似 页 式 机 制 ， 只 是 前 面 增加 一 项 段 号 。 所 以 ， 段 页 式 管理 存储 共享 容易 、 存 储 


保护 容易 。 
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rd: 量 忆 有 国内 某 知名 网 络 设备 提供 商 软 件 
工程 师 笔 试题 


1. 答案 : B。 

分 析 : 本 题 考察 的 是 对 Java 入 口 方法 的 理解 。 

public static void main(String[] args) 为 Java 程序 的 入 口 方法 ，JVM 在 运行 程序 时 ， 会 首先 
查找 main 方法 。 其 中 ，public 是 权限 修饰 符 ， 表 明 任 何 类 或 对 象 都 可 以 访问 这 个 方法 ，static 
表明 main 方法 是 一 个 静态 方法 ， 即 方法 中 的 代码 是 存储 在 静态 存储 区 的 ， 只 要 类 被 加 载 后 ， 
就 可 以 使 用 该 方法 而 不 需要 通过 实例 化 对 象 来 访问 ， 可 以 通过 类 名 .main() 直 接 访问 。JVM 在 
启动 时 就 是 按照 上 述 方法 的 签名 (必须 有 public 与 static 修饰 ， 返 回 值 为 void， 且 方法 的 参数 
为 字符 串 数 组 ) 来 查找 方法 的 入 口 地 址 ， 如 果 能 找到 就 执行 ， 如 果 找 不 到 则 会 报错 。void 表 
明 方 法 没有 返回 值 ，main 是 JVM 识别 的 特殊 方法 名 ， 是 程序 的 入 口 方法 。 字 符 串 数组 参数 
args 为 开发 人 员 在 命令 行 状态 下 与 程序 交互 提供 了 一 种 手段 。 
因为 main 为 程序 的 入 口 方法 ， 所 以 ， 当 程序 运行 时 ， 第 一 个 执行 的 方法 就 是 main 方法 。 通 
常 来 讲 ， 要 执行 一 个 类 的 方法 ， 首 先 必 须 实 例 化 一 个 类 的 对 象 ， 然 后 通过 对 象 来 调用 这 个 方法 。 
但 是 由 于 main 是 程序 的 入 口 方法 ， 此 时 还 没有 实例 化 对 象 ， 因 此 ， 在 编写 main 方法 时 ， 就 要 求 
不 需要 实例 化 对 象 就 可 以 调用 这 个 方法 ， 鉴 于 此 ，main 方法 需要 被 定义 成 public 与 static。 

本 题 中 ， 对 于 选项 A， 方 法 的 参数 没有 字符 串 数 组 ， 因 此 不 满足 入 口 方法 要 求 。 所 以 ， 
选项 A 错误 。 

对 于 选项 B， 描 述 正确 。 

对 于 选项 C, 方法 没有 被 static 修饰 ,因此 也 不 满足 入 口 方法 的 要 求 。 所 以 , 选项 C 错误 。 

对 于 选项 D， 返 回 值 不 是 void， 不 满足 要 求 。 所 以 ， 选 项 DD 错误 。 

所 以 ， 本 题 的 答案 为 了 B。 

2. 答案 : A。 

分 析 : 本 题 考 察 的 是 对 Java 文件 格式 的 理解 。 

对 于 选项 A 与 选项 B，Java 程序 源 文 件 的 后 级 为 java， 编 译 生成 中 间 代 码 文 件 的 后 级 名 
为 .class， 所 以 ， 选 项 A 正确 ， 选 项 B 错误 。 

对 于 选项 C， 在 Web 开发 中 ， 静 态 网 页 文件 的 后 绥 为 .html。 所 以 ， 选 项 C 错误 。 

对 于 选项 D， 一 般 情况 下 ，Windows 操作 系统 中 可 执行 文件 的 后 级 为 .exe。 所 以 ,选项 DD 
并 误 。 

所 以 ， 本 题 的 答案 为 A。 

3. 答案 : A。 

分 析 : 本 题 考察 的 是 对 前 置 自 增 ( 自 减 ) 和 后 置 自 增 ( 自 减 ) 的 理解 。 

在 编程 的 时 候 ， 经 常会 用 到 变量 的 自 增 或 自 减 操作 ， 尤 其 在 循环 中 用 得 最 多 。 以 自 增 为 
例 ， 有 两 种 自 增 方式 : 前 置 与 后 置 ， 即 ++i 和 计 +， 它 们 的 不 同 点 在 于 it+ 是 在 程序 执行 完毕 
后 自 增 ， 而 ++i 是 在 程序 开始 执行 前 进行 自 增 。 

对 于 本 题 而 言 ， 在 执行 语句 yt=z--/HHx 时 ，z-- 是 在 这 个 表达 式 计算 结束 后 才 执 行 自 减 操作 ， 


Me 


289 


梧 试 笔试 真题 尼 


Java 程序 员 


a 


先 执行 x 自 增 操作 , x 的 值 变 为 2， 
(运算 结果 需要 被 转换 为 int 类 型 ， 
所 以 ， 本 题 的 答案 为 A。 

4. 答案 : D。 

分 析 : 本 题 考察 的 是 对 App 
Applet 程序 的 开发 必须 继承 
(1) initO 

当 Applet 局 动 的 时 候 ， 调 月 
这 个 方法 中 一 般 做 一 些 初始 
(2) start() 

将 


此 ， 


昌 完 构造 方法 后 ， 就 会 调 月 


因此 ， 在 这 个 表达 式 中 ，z 的 值 为 3， 在 表达 式 计算 完成 后 ，z 的 值 变 为 4， 而 ++x 则 不 同 ， 会 首 


然后 参与 运算 ， 因 
丢弃 掉 小 数 部 分 )。 


此 ， 上 面 表 达 式 等 价 于 y+=3/2， 显然 ,3/2=1 


因此 ，y 的 值 变 为 3。 所 以 ， 选 项 A 正确 。 


let 开发 的 理解 。 


Applet 类 ， 它 有 5 个 比较 重要 的 方法 ， 如 下 所 示 : 


有 init 方法 做 一 些 初始 化 的 工作 。 
化 的 工作 。 所 以 ， 选 项 C 错误 。 


Applet 第 


次 启动 后 ， 调 用 完 init 方法 后 ， 就 会 调用 start 方法 来 启动 需要 的 一 些 线程 。 或 者 


当 用 户 离开 HTML 页 面 ， 然 后 重新 返回 页 面 的 时 候 ，start 方法 也 会 被 调用 。 所 以 ， 选 项 A 错误 。 


(3) paint(Graphics g) 
Applet 每 次 重 绘 的 时 候 都 会 

成 自己 的 画图 的 工作 。 所 以 ， 选 
(4) stopO 


沐 必 > 
个 类 完 


调用 paint 方法 进行 画图 。 在 开发 的 时 候 ， 需 要 继承 这 
项 D 正确 。 


这 个 方法 与 start 方法 是 相对 应 的 ， 当 用 户 离开 HTML 页 面 的 时 候 ，stop 方法 会 被 调 月 
用 来 停止 start 方法 中 启动 的 线程 


($5) destory() 


当 Applet 终止 运行 时 ，destory 方法 会 被 调 


所 以 ， 本 题 的 答案 为 D。 

5. 答案 : C。 

分 析 : 本 题 考察 的 是 对 访问 

在 Java 语言 中 ， 类 访问 控 
来 修饰 类 成 员 变 量 或 属性 。 所 

所 以 ， 本 题 的 答案 为 C。 

二 、 填 空 题 

1. 答案 : 

分 析 : 本 题 考 察 的 是 对 App 

Applet 指 的 是 Java 小 应 月 
览 器 下 载 和 执行 的 一 种 Java 类 。 
调用 执行 。 

Applet 程序 帮 
必须 与 类 名 相同 ， 文 伯 

2. 答案 : 2，2。 


日 程序 ， 


o 


所 以 ， 选 项 B 错误 。 


]， 用 来 释放 所 占 月 


的 资源 。 


控制 符 的 理解 。 
央 符 只 有 三 种 ， 分 别 是 public、private 和 protected， 而 static 
以 ， 选 项 C 错误 。 


Applet, MyApplet.java。 


于 发 以 及 Java 基本 概念 的 理解 。 
是 能 够 嵌入 到 一 个 HTML 页 面 9 


碟 有 
它 不 需要 main0 方 法 ， 由 Web 浏览 器 


let 


日 


并 且 可 通过 Web 浏 
内 符 的 Java 虚拟 机 


-> 


[发 必须 继承 Applet 类 。 由 于 只 定义 了 一 个 类 ， 因 此 ， 这 个 类 所 在 的 文件 名 


F 名 只 能 是 MyApplet.java。 


分 析 : 本 题 考察 的 是 对 Java 编码 的 理解 。 


在 Java 语言 中 ， 默 认 使 用 的 Unicode 编码 方式 ， 即 每 个 字符 占用 两 个 字 节 ， 无 论 是 中 文 
字符 还 是 英文 字符 ， 都 会 占用 两 个 字 节 。 
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真题 详解 篇 


引申 ， 虽然 String 是 由 char 所 组 成 的 ， 但 是 它 采 用 了 一 种 更 加 灵活 的 方式 来 存储 ， 即 英 
文 占 用 一 个 字符 ， 中 文 占用 两 个 字符 ， 采 用 这 种 存储 方式 的 一 个 重要 作用 就 是 可 以 减少 所 需 
的 存储 空间 ， 提 高 存储 效率 。 

3. 答案 :编写 源 程 序 ， 编 译 生成 字 节 码 ， 解 释 执 行 。 

分 析 : 本 题 考察 的 是 对 Java 应 用 程序 的 基本 开发 流程 的 理解 。 

Java 应 用 程序 的 开发 过 程 如 下 : 首先 编写 代码 ， 代 码 文件 的 后 级 为 java， 然 后 编译 源 代 
码 ， 用 javac 命令 把 源 代码 编译 成 中 间 代 码 〈.class 文件 )， 最 后 用 java 命令 运行 中 间 代 码 。 

4. 答案 : Javac，4，.class。 

分 析 : 本 题 考 察 的 是 对 Java 基本 概念 的 理解 。 

在 Java 语言 中 ， 不 管 在 一 个 文件 中 定义 几 个 类 ， 使 用 javac 命令 编译 后 ， 每 个 类 都 会 生 
成 一 个 .class 文件 (.class 文件 的 名 字 为 类 名 )。 

5. 答案 : 0。 

参见 单 选 题 第 3 题 。 

表达 式 的 值 为 23〈 计 算 结束 后 ，i 的 值 变 为 3)， 运 算 结果 的 值 与 i 的 类 型 相关 ， 如 果 变 
量 i 为 int 类 型 ， 那 么 结果 为 0。 

6. 答案 : true，false。 

分 析 : 本 题 中 ， 由 于 x=5，y=6， 所 以 ，x<y 是 成 立 的 ， 因 此 ， 逻 辑 值 为 tue， 而 x >= y 
不 成 立 ， 因 此 ， 逮 辑 值 为 false。 

7. 答案 : 抽象 (abstract)，final。 
在 Java 语言 中 ， 可 以 通过 把 方法 声明 为 abstract 来 表示 这 个 方法 是 抽象 方法 ， 抽 象 方法 
是 没有 方法 体 的 ， 子 类 只 有 实现 了 父 类 的 抽象 方法 ， 才 能 被 实例 化 。 被 final 修饰 的 方法 是 不 
能 被 子 类 重 写 的 。 

8. 答案 : package MyPackage;， 程 序 第 一 句 

package 的 中 文 意思 是 包 ， 它 是 一 个 比较 抽象 的 逻辑 概念 ， 它 的 宗旨 是 把 .java 文件 (Java 
源 文件 )、.class 文件 (编译 后 的 文件 ) 以 及 其 他 resource 文件 (例如 .xml 文件 、.avi 文件 、.mp3 
文件 和 .txt 文件 等 ) 有 条 理 地 进行 组 织 ， 以 供 使 用 。 它 类 似 于 Linux 文件 系统 ， 有 一 个 根 ， 然 
后 从 根 开始 有 目录 和 文件 ， 目 录 中 肉 套 有 目录 。 
具体 而 言 ，package 主要 有 两 个 作用 : 第 一 ， 提 供 多 层 命令 空间 ， 解 决 命名 冲突 ， 通 过 使 
用 package， 使 得 处 于 不 同 package 中 的 类 可 以 存在 相同 的 名 字 ; 第 二 ， 对 类 按 功能 进行 分 类 ， 
使 项 目的 组 织 更 加 清晰 。 当 开发 一 个 有 非常 多 的 类 的 项 目 时 ， 如 果 不 使 用 package 对 类 进行 
分 类 ， 而 是 把 所 有 的 类 都 放 在 一 个 package 下 ， 这 样 的 代码 不 仅 可 读 性 差 ， 而 且 可 维护 性 也 
不 好 ， 会 严重 影响 开发 效率 。 

package 的 用 法 如 下 《〈 源 文件 所 在 目录 为 当前 目录 ): 在 每 个 源 文件 的 开头 (必须 在 开头 ) 
加 上 “package packagename; ”。 

9. 答案 : 160。 

分 析 : 这 个 程序 的 功能 是 把 数组 下 标 为 偶数 的 项 相 加 : 10+30+50+70=160。 

10. 答案 : 单 ， 多 。 

在 Java 语言 中 ， 只 人 允许 单 重 继承 ， 也 就 是 说 ， 任 何 一 个 类 都 只 能 有 一 个 父 类 ， 但 是 Java 
语言 引入 了 接口 的 概念 ， 一 个 类 可 以 同时 实现 多 个 接口 ， 从 而 间接 地 实现 了 多 重 继承 。 


Pull 


to 
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三 、 写 出 下 列 程序 完成 的 功能 

1. 答案 : 程序 的 功能 为 从 控制 台 输 入 5 个 数 ， 保 存 到 数组 中 ， 然 后 把 数组 中 的 内 容 逆序 
输出 《通过 从 数组 的 最 后 一 个 元 素 开始 遍历 而 实现 逆序 )。 

2. 答案 : 程序 的 功能 为 得 到 将 1 到 1/100 相 加 的 结果 ， 并 输出 。 

3. 答案 : 这 个 类 的 calculate 方法 用 来 计算 timeConsumingOperation() 执 行 testSum 次 的 平 
均 执 行 时 间 、 最 长 执行 时 间 和 最 短 执行 时 间 。 

四 、 写 出 下 面 程 序 的 运行 结果 

1. 答案 ， Hello world 

world 

分 析 : 本 题 中 ， 在 调用 new Str(str1,str2) 的 时 候 ， 初 始 化 了 一 个 临时 的 Str 的 实例 (s1= 
"Hello!"，s2="world" )， 当 调用 System.out.println 方法 输出 这 个 对 象 的 时 候 ， 会 调用 这 个 对 象 
的 toString 方法 ， 返 回 s1+s2， 显 然 ， 返 回 值 为 Hello world。 在 这 个 过 程 中 ，str2 的 值 被 初始 
化 以 后 就 没有 被 修改 过 ， 因 此 ， 接 下 来 输出 str2 的 值 : world。 


2. 答案 : Ex,no-args 


-> 


Fx,no-args 

Fx,int 

分 析 : 只 有 当 子 类 的 构造 方法 没有 调用 父 类 的 构造 方法 的 时 候 ， 编 译 器 才 会 默认 地 去 调 
用 父 类 中 无 参数 的 构造 方法 。 对 于 本 题 而 言 ， 类 Fx 中 无 参数 的 构造 方法 显然 已 经 调用 了 父 类 
的 构造 方法 , 而 Fx 类 中 带 参 数 的 构造 方法 也 通过 调用 无 参数 的 构造 方法 间接 调用 了 父 类 的 构 
造 方法 ， 因 此 ， 编 译 器 不 会 在 调用 Fx 类 有 参数 的 构造 方法 的 时 候 再 去 调用 父 类 的 构造 方法 。 
在 调用 Fx fnew Fx(5) 的 时 候 ， 先 调用 Fx 的 构造 方法 ， 在 这 个 方法 中 ， 首 先 调用 无 参数 的 构 
造 方法 ， 在 无 参数 的 构造 方法 中 ， 首 先 调 用 父 类 的 无 参数 的 构造 方法 输出 Ex,no-args， 接 着 在 
类 Fx 无 参数 的 构造 方法 中 输出 Fx,no-args， 最 后 调用 类 Fx 有 参数 的 构造 方法 ， 输 出 Fx,int。 


5 开国 内 攻 顶 级 手机 制造 商 软件 工程 师 笔试 题 


一 、 选 择 题 


ls 6 
分 析 : 本 题 考察 的 是 对 值 传递 与 引用 传递 的 理解 。 
本 题 中 ， 方 法 调用 的 执行 过 程 如 图 28 所 示 。 


changeStr 方 法 调用 开始 时 changeStr 方 法 调用 即将 结束 的 时 候 
量 


main 方 法 栈 常 


区 main 方 法 栈 


Str hello Str 


changeStr 栈 world 


changeStr 栈 


| 


图 28 方法 调用 的 执行 过 程 
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在 调用 方法 changeStr 的 时 候 , 会 把 实 参 的 值 (main 方法 中 的 str) 赋值 给 形 参 (changeStr 
方法 中 的 str)， 这 个 赋值 可 以 理解 为 把 字符 串 “hello” 的 引用 《或 地 址 ) 赋值 给 了 形 参 。 在 方 
法 changeStr 中 执行 语句 str="world" 的 结果 是 使 得 changeStr 中 的 临时 变量 str 指向 了 另外 一 个 
新 的 字符 串 ， 但 是 这 个 赋值 对 实 参 的 值 是 没有 影响 的 。 当 方法 调用 结束 后 ，changeStr 方法 中 
的 str 变量 的 作用 域 将 结束 ， 因 此 ， 也 就 不 存在 了 ， 此 时 ，main 方法 中 的 str 变量 的 值 没 有 改 
变 ， 因 此 ， 输 出 的 结果 为 字符 串 “phello”。 所 以 ， 选 项 A 正确 。 

所 以 ， 本 题 的 答案 为 A。 

2. 答案 : A。 

分 析 : 本 题 考 察 的 是 for 循环 的 知识 。 

for 循环 语句 的 基本 结构 如 下 : 

for( 表 达 式 1; 表 达 式 2; 表 达 式 3) 
循环 体 
} 

它 的 执行 过 程 如 下 : 

1) 首先 执行 初始 化 语句 : 表达 式 1 (只 会 被 执行 一 次 )。 

2) 然后 执行 表达 式 2， 如 果 表 达 式 2 的 结果 为 false， 则 结束 循环 ， 否 则 ， 执 行 循环 体 ， 
然后 执行 表达 式 3。 

3) 循环 执行 步骤 2)， 直 到 表达 式 2 的 结果 为 false 时 ， 则 退出 循环 ， 或 者 循环 体内 有 退 
出 循环 的 语句 〈return 或 break )。 

对 于 本 题 而 言 ， 执 行 步骤 如 下 : 

1) 首先 执行 foo(‘A’) 输 出 字符 'A'。 

2) 接着 执行 foo('B') && (i < 2)， 输 出 字符 'B'， 且 这 个 表达 式 的 结果 为 tue， 因 此 ， 执 行 
循环 体 i 计 + 执行 后 i 的 值 变 为 1)， 接 着 输出 字符 D'， 然 后 执行 fpo(C7)， 输 出 字符 'C'。 

3) 重复 第 2) 步 ， 由 于 此 时 i 的 值 为 1， 因此， 循环 条 件 为 tue， 接 着 会 输出 字符 'B'、'D'、 
'C'。 结 束 这 一 次 循环 后 ，i 的 值 变 为 2; 然后 继续 执行 循环 条 件 foo('B') && (i < 2)， 首 先 执 行 
foo(B') 输 出 字符 'B'， 因 为 foo('B') 执 行 的 结果 为 ttue， 所 以 需要 继续 执行 判断 语句 i1< 2， 显 然 
返回 值 为 false， 此 时 循环 结束 。 
因此 ， 程 序 的 输出 结果 为 ABDCBDCB。 

所 以 ， 本 题 的 答案 为 A。 

3. 答案 : A、C。 

分 析 : 本 题 考察 的 是 多 态 的 知识 。 

多 态 指 的 是 允许 不 同类 的 对 象 对 同一 消息 做 出 响应 。 即 同一 消息 可 以 根据 发 送 对 象 的 不 
同 而 采用 多 种 不 同 的 行为 方式 〈 发 送 消息 就 是 函数 调用 )。 实 现 多 态 的 方法 是 动态 绑 定 
(Dynamic Binding)， 动 态 绑 定 指 的 是 在 执行 期 间 判 断 所 引用 对 象 的 实际 类 型 ， 根 据 其 实际 的 
类 型 调用 其 相应 的 方法 。 

在 Java 语言 中 ，Override 〈 履 盖 、 重 写 ) 是 实现 多 态 的 关键 技术 ， 在 子 类 中 定义 与 父 类 
相同 的 方法 ， 同 时 有 自己 不 同 于 父 类 的 实现 ， 在 使 用 的 时 候 可 以 用 父 类 的 引用 指 问 不 同 的 子 
类 ， 从 而 在 运行 时 决定 调用 哪个 子 类 的 方法 。 多 态 的 实现 有 如 下 要 求 : 
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1 ) 子 类 方法 与 父 类 方法 名 字 相 同 。 

2) 子 类 方法 与 父 类 方法 有 相同 的 参数 列表 〈 相 同 的 参数 个 数 与 类 型 )， 如 果 参 数列 表 不 
一 样 ， 则 不 是 重 写 ， 而 是 重 载 。 

3) 当 方法 名 与 参数 列表 相同 的 时 候 ， 返 回 值 必 须 相 同 。 

4) 子 类 重 写 的 方法 的 可 见 性 必须 大 于 或 等 于 父 类 方法 的 可 见 性 。 

5) 不 能 用 子 类 的 静态 方法 隐藏 父 类 的 实例 方法 。 

6) 不 能 用 子 类 的 实例 方法 隐藏 父 类 的 静态 方法 。 

显然 ， 选 项 A 是 正确 的 。 

对 于 选项 B， 如 果 方 法 被 private 修饰 ， 那 么 该 方法 的 可 见 性 就 会 被 降低 。 因 此 ， 选 项 B 


对 于 选项 C， 这 个 方法 参数 有 不 同 的 类 型 ， 相 当 于 从 父 类 继承 method 方法 后 又 重 载 了 这 
个 方法 。 因 此 ， 选 项 C 正确 。 

对 于 选项 D， 不 能 用 类 方法 来 隐藏 父 类 实例 方法 。 因 此 ， 选 项 DD 错误 。 

对 于 选项 卫 ， 方 法 名 和 方法 参数 与 父 类 相同 ， 但 是 返回 值 却 不 同 。 因 此 ， 选 项 E 错误 。 

所 以 ， 本 题 的 答案 为 A、C。 

4. 答案 : A。 

分 析 : 本 题 考 察 的 是 对 非 静 态 内 部 类 实例 化 的 方法 的 理解 。 

非 静 态 内 部 类 是 定义 在 一 个 类 内 部 的 类 ， 它 与 一 个 实例 绑 定 在 一 起 ， 不 可 以 定义 静态 的 
属性 和 方法 。 只 有 在 外 部 的 类 被 实例 化 后 ， 这 个 内 部 类 才能 被 实例 化 。 一 般 而 言 ， 实 例 化 内 
部 类 的 方法 为 : 外 部 类 类 名 .内 部 类 类 名 对 象 名 = 外 部 类 对 象 名 .new 内 部 类 类 名 0。 当 然 ， 也 
可 以 在 外 部 类 的 对 象 方法 中 直接 实例 化 内 部 类 。 

本 题 中 ， 对 于 选项 A，Java 语言 规定 ， 要 么 是 类 名 .方法 0〈 此 时 的 方法 必须 是 静态 方法 )， 
要 么 是 对 象 .方法 0, 除 此 以 外 的 写法 都 不 正确 。 本 题 中 , someOuterMethod 是 一 个 对 象 的 方法 ， 
只 有 当 外 部 类 被 实例 化 以 后 ， 这 个 方法 才能 被 调用 ， 当 外 部 类 实例 化 以 后 ， 当 然 就 可 以 实例 
化 内 部 类 了 。 因 此 ， 选 项 A 正确 。 
对 于 选项 B， 由 于 main 方法 是 一 个 static〈 静 态 ) 方法 ， 在 对 象 没有 实例 化 的 时 候 就 可 
以 被 调用 ， 而 非 静 态 内 部 类 依赖 于 外 部 类 的 对 象 ， 因 此 ， 在 外 部 类 没有 被 实例 化 的 时 候 ， 不 
能 直接 实例 化 内 部 类 。 因 此 ， 选 项 B 错误 。 

对 于 选项 C，Java 语言 中 没有 类 名 .类 名 0 的 语法 。 因 此 ， 选 项 C 错误 。 

对 于 选项 D， 这 种 写法 是 错误 的 ， 因 为 Inner 是 一 个 内 部 类 ， 并 不 是 一 个 方法 ， 而 对 象 . 
方法 0 才 是 被 允许 的 写法 ， 没 有 对 象 .类 名 这 个 用 法 。 因 此 ， 选 项 DD 错误 。 

所 以 ， 本 题 的 答案 为 A。 

5. 答案 : B。 

分 析 : 本 题 考察 的 是 对 Servlet 中 常用 方法 的 理解 。 

session 译 为 会 话 ， 指 的 是 有 始 有 终 的 一 系列 动作 /消息 ， 例 如 在 打 电 话 时 ， 从 拿 起 电话 拨 
号 到 挂 断 电话 这 中 间 的 一 系列 过 程 可 以 称 为 一 个 session。 当 程序 需要 为 某 个 客户 端的 请 求 创 
建 一 个 session 的 时 候 ， 服 务 器 会 首先 检查 这 个 客户 端的 请 求 里 是 否 已 经 包含 了 一 个 session 
标识 ， 这 个 标识 被 称 为 session ID 。 如 果 已 经 包含 一 个 session ID， 则 说 明 以 前 已 经 为 此 客户 
端 创建 过 session， 此 时 服务 器 就 按照 session ID 把 这 个 session 检索 出 来 使 用 (如 果 检 索 不 到 ， 
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可 能 会 新 建 一 个 )， 如 果 客 户 端 请 求 不 包含 session ID， 则 为 此 客户 端 创建 一 个 session， 并 且 
生成 一 个 与 此 session 相关 联 的 session ID。 

HttpServletResponse 接口 提供 了 重 写 URL 的 方法 ， 如 下 所 示 ; 

public java.lang.String encodeURL(java.lang.String url) ; 

该 方法 的 实现 机 制 如 下 : 先 判断 当前 的 Web 组 件 是 否 启 用 session， 如 果 没 有 启用 
session， 则 直接 返回 参数 url， 再 判断 客户 端 浏览 器 是 否 文 持 cookie， 如 果 文 持 cookie， 则 直 
接 返 回 参数 url; 如 果 不 支 持 cookie， 就 在 参数 url 中 加 入 session ID 信息 ， 然 后 返回 修改 后 
的 url。 因 此 ， 这 个 方法 可 以 用 来 把 sessionID 加 入 到 URL 中 。 所 以 选项 B 正确 。 

所 以 ， 本 题 的 答案 为 B。 

6. 答案 : B、G。 

分 析 : 本 题 考察 的 是 对 JSP 直接 调用 Java 代码 和 JSP 内 置 动作 的 理解 。 

JSP 主要 有 两 种 方法 来 调用 Java 代码 : 一 种 是 在 JSP 文件 中 的 <% ”%> 内 调用 Java 代码 ， 
另外 一 种 是 通过 JSP 的 内 置 对 象 调用 Java 代码 。 

对 于 本 题 而 言 ， 选 项 B 是 调用 对 象 YoshibBeen 的 getSize 方法 ， 而 选项 G 通过 内 置 对 象 
getProperty 也 是 调用 YoshiBean 的 getSize 方法 ， 二 者 等 价 。 所 以 ， 选 项 B 与 选项 G 正确 。 

所 以 ， 本 题 的 答案 为 B、G。 

二 、 简 答题 

1. 答案 : Struts 的 名 字 来 源 于 在 建筑 与 日 式 飞 机 中 使 用 的 支持 金属 识 ， 它 是 由 自 定义 标 
签 、 信 息 资 源 (Message Resources)、Servlet 和 JSP 组 成 的 一 个 可 重用 的 MVC2 模式 的 框架 。 
以 Struts1.0 为 例 ， 其 结构 图 如 图 29 所 示 。 


Controller 
Servlet i ine ic 
(Servlet) 人 Dispatch Business Logic 
1. Http Rqqucst (Action) 
Client 
(Browser) 4. Forward 8 Gat 
6.Http Response | 
View Model 
(JSP) 儿 5. get through tag 一] 本 ni 


图 29 _ Struts1.0 结构 图 


从 图 29 可 以 看 出 ，Struts 的 体系 结构 采用 了 MVC 设计 模式 ， 同 时 包含 客户 端 (Client) 
请 求 以 及 业务 逻辑 处 理 (Business Logic) , 而 MVC 设计 模式 主要 由 模型 (Model)、 视 图 (View) 
和 控制 器 〈Controller) 三 部 分 组 成 。 

以 下 将 分 别 对 这 些 模 块 进行 介绍 。 

(1) 客户 端 (Client) 

客户 端 一 方面 可 以 通过 浏览 器 发 送 HTTP 请 求 ， 男 一 方面 可 以 把 接收 到 的 HTTP 响应 消 
息 在 浏览 器 上 展现 出 来 。 

(2) 控制 器 《〈Controller) 
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控制 器 主要 包括 ActionServlet 类 和 RequestProcessor 类 。 


实现 的 控制 器 部 分 ， 


模型 模块 中 获取 用 户 所 需 的 数据 ， 然 后 选择 合适 的 视图 来 响应 用 户 的 请 求 。 
计 模 式 来 实现 这 个 功能 : 通过 struts-config.xml 配置 文件 来 丰 
用 户 请 求 的 时 候 ， 关 于 请 求 的 处 理 大 部 分 已 交 由 RequestProcessor.process(0) 方 法 来 处 理 。 
明了 模板 的 设计 模式 (按照 处 理 的 步骤 与 流程 顺序 的 调 


RequestProcessor 类 的 processs(0) 方 法 采 月 


用 了 一 系列 的 方法 )。 
处 理 的 主要 流程 如 下 


其 中 ， 
是 整个 框架 的 核心 部 分 ， 它 用 来 接收 用 户 的 请 求 ， 并 根据 用 户 的 请 求 从 


ActionServlet 类 是 MVC 


角 定 处 理 请 求 的 Action 类 。 


它 采用 了 命令 设 


在 处 理 


1) processPath(request, response)。 根 据 URI (Uniform Resource Identifier， 统 一 资源 标识 
符 ， 用 来 唯一 地 标识 一 个 资源 ) 来 得 到 ActionMapping 元 素 的 路 径 。 


2) processMapping(request, rfesponse)。 根 据 路 径 信 ， 

3 ) processRoles(request,respose, mapping)。 

户 登 录 的 时 候 ， 会 通过 processRoles 方法 调 
有 权限 来 执行 给 定 的 ActionMapping。 

4) processValidate(request, response, form, mapping)。 调 月 


息 找 到 ActionMapping 对 象 。 


Struts 为 Web 应 


提供 了 一 种 认证 机 制 ， 当 用 
] requestisUserInRole() 方 法 来 检查 这 个 


] 户 是 否 


日 ActionForm 的 validate0 方 法 。 


5) processActionCreate(request, response, mapping)。 这 个 方法 从 <action> 的 type 属性 得 到 


Action 类 名 ， 并 创建 返回 


它 的 实例 。 


6) processActionPerform(req，res，action，form，mapping)。 这 个 方法 调用 Action 类 的 


execute() 方 法 ， 其 中 ，exe 
是 线程 安全 的 。 


cute0) 方 法 中 包含 了 业务 逻辑 的 实现 。 


(3) 业务 逻辑 (Business Logic) 
Servlet 在 接收 到 请 求 后 会 根据 配置 文件 中 的 对 应 关系 ， 把 请 求 转 给 指定 的 Action 类 来 处 
理 。Action 类 采用 适配器 设计 模式 , 它 只 是 对 业务 逻 辑 进行 了 包装 (真正 的 业务 逻辑 是 由 EJB 
的 session bean 或 普通 的 Java 类 来 实现 的 )。 


(4) 模型 (Model) 
在 Struts 的 体系 结构 


中 ,模型 分 为 两 个 部 分 : 系统 的 内 部 状态 和 


务 逻 辑 )。 内 部 状态 通常 由 
的 类 或 对 象 。ActionForm 是 一 个 抽象 类 ， 每 一 个 输入 表单 都 对 应 着 它 的 一 个 子 类 。 
struts-config.xml 中 保存 了 HTTP 请 求 表单 与 具体 ActionForm 类 的 上 四 


(5) 视图 (View) 


组 Actionform Bean 表示 ，ActionForm 


需要 注意 的 是 ，Action 类 并 不 


1 可 以 改变 状态 的 操作 ( 业 
封装 了 HTTP 请 求 的 数据 
配置 文件 


里 关 系 。 


视图 就 是 一 个 JSP 文件 ， 在 该 JSP 文件 中 ， 没 有 业务 逻辑 的 处 理 ， 也 不 保存 系统 的 状态 


信息 


Lv 


Tags、HTML Tags、LogicTags、NestedTags 以 及 TemplateTags 等 。 


它 通过 一 些 标签 来 把 数据 以 浏览 器 能 识别 的 方式 展现 出 来 。 目 前 ， 标 签 库 主 要 有 Bean 


Struts 框架 作为 一 项 ] 


1) 由 于 采用 了 MYVC 模式 ， 所 以 它 实 现 了 表现 与 逻辑 的 分 离 ， 使 得 系统 有 较 好 的 可 扩 
(Taglib) 包含 了 大 量 的 tag， 有 助 于 提高 系统 的 开发 效率 。 


性 。 同 时 Struts 的 标记 库 


Tf 放 源码 项 目 ， 优 点 众多 ， 具 体 而 言 ， 主 要 有 如 下 儿 点 : 


型 


2) 提供 了 页 面 导 航 功能 ， 使 系统 的 脉络 更 加 清晰 。 通 过 一 个 配置 文件 建立 整个 系统 各 部 


分 之 间 的 联系 ， 使 得 系统 
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结构 变 得 更 加 清晰 ， 从 而 增强 系统 的 可 扩展 性 与 可 维护 性 。 
3) 提供 了 表单 的 验证 功能 ， 进 一 步 增 强 了 系统 的 健壮 性 。 


4) 提供 了 数据 库 连 接 池 管 理 。 

5) 提供 了 Exception 处 理 机 制 。 

6) 文 持 国际 化 。 

当然 ，Struts 也 有 其 不 足 之 处 ， 主 要 表现 为 以 下 几 点 : 

1) Taglib 中 包含 了 大 量 的 tag， 对 于 初学 者 而 言 ， 开 发 难度 比较 大 。 

2) Struts 开发 中 包含 了 许多 xml 格式 的 配置 文件 。 一 方面 ， 这 些 配置 文件 不 好 调试 ， 另 
一 方面 ， 大 量 的 xml 文件 也 不 便于 管理 。 

3) Struts 只 能 支持 Web 应 用 程序 的 开发 。 

4) Struts 的 Action 不 是 线程 安全 的 ， 因 此 ，Action 类 用 到 的 所 有 资源 都 必须 进行 同步 。 

5) 单元 测试 不 方便 。 由 于 Action 与 Web 层 的 紧 耦 合 的 特点 导致 其 非常 依赖 于 Web 容器 ， 
给 单元 测试 带 来 不 便 。 

6) 部 署 肪 烦 。 当 转 到 表示 层 时 ， 需 要 配置 forward， 例 如 ， 如 果 有 10 个 表示 层 的 JSP 
文件 ， 则 需要 配置 10 个 Struts。 此 外 ， 当 目录 、 文 件 变更 后 ， 需 要 重新 修改 forward， 而 
且 每 次 修改 配置 之 后 ， 还 需要 重新 部 署 整个 项 目 ， 对 于 Tomcat 等 服务 器 ， 还 必须 重新 启 
动 服务 器 。 

7) 对 Servlet 的 依赖 性 过 强 。 当 Struts 处 理 Action 时 ， 必 需要 依赖 ServletRequest 和 
ServletResponse， 摆 脱 不 了 对 Servlet 容器 的 依赖 。 

2. 答案 : XML 包括 DOM (Document Object Modal) 文档 对 象 模型 和 SAX (Simple API 
forXML)。 其 中 ，DOM 是 一 次 性 将 整个 文档 读 入 内 存 操作 ， 如 果 文 档 比 较 小 ， 读 入 内 存 ， 可 
以 极 大 地 提高 操作 的 速度 , 但 如 果 文 档 比 较 大 ,那么 就 比较 费劲 。 所 以 ，SAX 应 运 而 生 , SAX 
不 是 一 次 性 地 将 整个 文档 读 入 内 存 ， 它 适用 于 处 理 大 型 文档 。 

3. 答案 ; 

(1) 内 置 对 象 
在 JSP 中 ， 内 置 对 象 又 称 为 隐 仿 对象， 是 指 在 不 声明 和 创建 的 情况 下 就 可 以 被 使 用 的 一 
些 成 员 变 量 。JSP 一 共 提 供 有 9 个 内 置 对 象 ， 分 别 是 request (请求 对 和 象 )、response (响应 对 
象 )、pageContext (页 面 上 下 文 对 象 )、session 〈 会 话 对 象 )、application 〈 应 用 程序 对 象 )、out 
(输出 对 象 )、config (配置 对 象 )、page〈 页 面 对 象 ) 与 exception〔 例 外 对 象 )。 其 具体 的 描述 
见 表 15。 


Nl 


表 15 内 置 对 象 

名 称 描述 

客户 端 请 求 ， 此 请 求 包含 来 自 GET/POST 请 求 的 参数 。 客 户 端的 请 求 信息 被 封装 在 request 对 象 中 ， 
通过 它 才能 了 解 到 客户 的 需求 ， 然 后 做 出 响应 ， 因 此 ，request 对 象 是 用 来 获取 请 求 参 数 的 非常 重要 途 
。 它 是 HttpServletRequest 类 的 实例 
来 表示 服务 器 端 对 客户 端的 响应 ， 将 Web 服务 器 处 理 后 的 结果 返回 给 客户 端 。 但 在 JSP 中 ， 很 少 
直接 使 用 到 它 。 它 是 HttpServletResponse 类 的 实例 
提供 了 对 JSP 页 面 所 有 的 对 象 及 命名 空间 的 访问 ， 也 就 是 说 ， 用 它 可 以 访问 到 本 页 面 中 所 有 其 他 的 
对 象 ， 例 如 前 面 已 经 描述 的 request、response 以 及 后 面 要 介绍 的 session 和 application 对 象 等 。 它 的 本 
类 名 也 叫 pageContext 
来 表示 客户 端 与 服务 器 的 一 次 会 话 。 从 客户 端 与 Web 服务 器 建立 连接 的 时 候 会 话 开始 ， 直 到 关闭 
浏览 器 时 结束 会 话 。 它 是 HttpSession 类 的 实例 


Tequest 


response 


2 


pageContext 


session 
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( 续 ) 
名 称 描述 
代表 JSP 所 属 的 Web 应 用 本 身 。application 对 象 可 以 存放 全 局 变量 ， 因 此 ， 可 以 实现 用 户 间 的 数据 
ate 共享 。 它 的 生命 周期 与 服务 器 的 生命 周期 一 致 ， 也 就 是 说 ， 当 服务 器 启动 后 ， 这 个 对 象 被 创建 出 来 ， 
多 直到 服务 器 停止 后 这 个 对 象 的 生命 周期 才 结束 。 在 任何 地 方 对 此 对 象 属性 的 操作 ， 都 将 影响 到 其 他 
户 对 此 的 访问 。 它 是 ServletContext 类 的 实例 
Onut 于 在 客户 端 浏览 器 内 输出 信息 。 它 是 JspWriter 类 的 实例 
Cont 主要 作用 是 取得 服务 器 的 配置 信息 。 当 一 个 Servlet 初始 化 时 ， 容 器 把 某 些 信息 通过 config 对 象 传递 
9 给 这 个 Servlet，Servlet 可 以 使 用 这 个 对 象 获取 所 需 的 配置 信息 
page 表示 当前 JSP 页 面 ， 类 似 于 Java 语言 中 的 this 指针 。 它 是 java.lang.Object 类 的 实例 
二 来 表示 异常 。 当 一 个 页 面 在 运行 过 程 中 发 生 了 例外 ， 就 会 产生 这 个 对 象 。 如 果 JSP 需要 使 用 这 个 
对 象 就 必须 把 isErrorPage 设 为 true， 否 则 无 法 编译 。 它 是 java.lang.Throwable 的 对 象 


根据 它们 作用 的 不 同 , 可 以 将 以 上 9 个 内 置 对 象 分 为 4 类 : 第 一 类 , 与 Servlet 有 关 的 page 
和 config; 第 二 类 ， 与 Input/Output 有 关 的 out、request 和 response; 第 三 类 ， 与 Context 有 关 
的 application、session 和 pageContext; 第 四 类 ， 与 Error 有 关 的 exception 。 

(2) 内 置 动作 

JSP 使 用 动作 来 实现 动态 地 插入 文件 、 实 现 重 定向 和 对 JavaBean 的 引用 等 功能 。 它 一 共 
有 6 个 基本 动作 : jsp:include、jsp:useBean、jsp:setProperty、jsp:getProperty、jsp:forward 与 
jsp:plugin。 以 下 将 分 别 对 这 些 动 作 进 行 具体 介绍 。 

jsp:include: 用 来 在 页 面 被 请 求 的 时 候 引 入 一 个 文件 。include 指令 是 在 JSP 文件 被 转换 成 
Servlet 的 时 候 引 入 文件 ， 而 jsp:include 插入 文件 的 时 间 是 在 页 面 被 请 求 的 时 候 ， 而 且 被 引用 
文件 不 能 包含 其 些 JSP 代码 (例如 不 能 设置 HTTP 头 ) 。 使 用 示例 如 下 所 示 : 


DH 


<jsp:include page="test.jsp " flush="true"> 


=" ="value"/> 


<jsp:param name="name" value: 


</ jsp:include> 
以 上 代码 表示 在 当前 文件 中 可 以 引入 testjsp 文 伯 


jsp:useBean: 用 来 寻找 或 者 实例 化 一 个 JavaBean。 它 使 得 开发 人 员 既 可 以 发 挥 Java 组 件 
重用 的 优势 ， 同 时 也 避免 了 损失 JSP 区 别 于 Servlet 的 方便 性 。 使 用 示例 如 下 所 示 : 


I 


o 


ll 


<jsp:useBean id="car" scope="session" class="com.Car" > 


以 上 代码 表示 实例 化 一 个 com.Car 类 的 实例 。 
jsp:setProperty: 用 来 设置 已 经 实例 化 的 Bean 对 象 的 属性 。 使 用 示例 如 下 所 示 : 


<jsp:setProperty name=" car " property="colour" value="red" /> 


以 上 代码 用 来 设置 名 字 为 car 的 实例 的 colour 属性 为 red。 
jsp:getProperty: 用 来 获取 某 个 JavaBean 的 属性 。 使 用 示例 如 下 所 示 : 


Colour= <jsp:getProperty name="car" property="colour"></ jsp:getProperty> 


以 上 代码 用 来 获取 名 字 为 car 的 实例 的 colour 属性 。 


jsp:foward: 用 来 把 请 求 转 到 一 个 新 页 面 。 使 用 示例 如 下 所 示 : 
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<jsp:forward page="/Servlet/login" 这 


以 上 代码 把 当前 页 面 重 定向 到 /Servleblogin 来 处 理 

jsp:plugin: 用 于 在 浏览 器 中 播放 或 显示 一 个 对 象 。 使 用 这 个 动作 能 插入 所 需 的 特定 的 浏 
览 器 的 OBJECT 或 EMBED 元 素来 指定 浏览 器 运行 一 个 Java Applet 所 需 的 插件 。 使 用 示例 如 
下 所 示 : 


o 


<jsp:plugin type="applet" codebase="/ch5" code="Hello.class" height="40" width="320"> 


以 上 代码 用 来 在 浏览 器 中 运行 一 个 Applet 插件 。 

4. 答案 : 本 题 考察 的 是 对 like 子 句 中 通配符 % 的 理解 。 

'%%' 可 以 匹配 所 有 的 内 容 ， 但 是 不 能 匹配 空 《null)， 例 如 当 NAME 列 有 值 为 null 的 
记录 ，SELECT * FROM TABLE 就 能 查询 出 来 ， 而 后 面 的 那 条 SQL 语句 就 查询 不 出 来 这 
条 记录 。 

5.， 答案 ; 

1) 主要 思路 为 : 从 g cardapplydetail 中 找到 身份 证 号 对 应 的 g_ applyno， 然 后 根据 
g_applyno 在 表 g_cardapply 中 找 出 申请 日 期 即 可 ， 下 面 给 出 两 种 写法 : 

CD select tl.g applydate from g cardapply tl1，g cardapplydetail t2 where t2.g idcard= 
'612301430103082' and tl.g_applyno=t2.g_applyno 

© select g applydate from g cardapply where g idcard in (select g idcard from g 
cardapplydetail where g idcard='612301430103082') 

2) 本 题 的 主要 思路 为 :首先 按 映 份 证 号 码 进 行 分 组 ， 然 后 统计 每 个 喘 份 训 
最 后 把 出 现 次 数 大 于 或 等 于 2 的 信息 查询 出 来 ，SQL 语句 如 下 : 

selectg_idcard, count(g idcard) as num from g cardapplydetail group by g idcard having 


Fy 


Ll 


8 现 的 次 数 ， 


count(g_ idcard)>1 
3) 更 新 记录 需要 使 用 update 语句 ， 可 以 使 用 两 条 SQL 语句 分 别 更 新 两 张 表 : 
updateg cardapplydetailset g_state=']l5' where g ldcard='612301430103082， 
updateg cardapply set g state='l$' where g applyno in (select g applyno fom g_ 
cardappdetall where g idcard='612301430103082") 
当然 也 可 以 把 这 两 个 SQL 语句 写 到 一 个 存储 过 程 里 面 ， 存 储 过 程 的 参数 为 身份 证 
号 码 。 
为 了 保持 数据 库 中 数据 的 一 致 性 ， 最 好 把 这 两 条 update 语句 放 到 一 个 事务 中 。 
4) 本 题 考 察 的 是 对 like 子 句 模糊 查询 的 理解 ，SQL 语句 如 下 : 
delete from g_cardapplydetailwhere g_name like ' 张 % 


某 顶 级 大 数据 综合 服务 提供 商 软件 工 
程 师 笔试 是 


1 


也 
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分 析 : 本 题 考 察 的 是 对 Java 类 型 的 理解 。 

在 Java 语言 中 ，Short 是 short 的 包装 类 〈 包 装 类 是 什么 ? 其实 ， 虽 然 Java 语言 是 一 
个 纯 面 向 对 象 的 语言 ， 但 是 ，Java 语言 中 的 基本 数据 类 型 却 不 是 面向 对 和 象 的 ， 从 而 导致 了 
实际 使 用 中 的 诸多 不 便 ， 为 了 解决 这 个 问题 ， 在 设计 类 时 ， 为 每 个 基本 数据 类 型 设计 了 一 
个 对 应 的 类 进行 代表 ， 这 样 8 种 与 基本 数据 类 型 对 应 的 类 统称 为 包装 类 )， 本 题 中 ,变量 a 


是 Short 类 的 对 象 ， 而 byte 是 Java 语言 的 8 种 基本 类 型 之 


于 无 法 将 一 个 对 象 转换 为 


基本 类 型 ， 因此， 本 题 中 示例 会 编译 错误 。 如 果 把 Short 改 成 short， 则 能 编译 通过 。 所 以 ， 


选项 DD 正确 。 
所 以 ， 本 题 的 答案 为 D。 


2. 答案 : A。 


分 析 : 本 题 考察 的 是 对 栈 的 到 
栈 是 一 个 后 进 先 出 、 先 进 后 出 的 数据 结构 ， 当 采用 选项 A 的 方案 时 ， 两 个 栈 的 栈 底 位 置 
向 中 间 延 伸 ， 两 个 栈 的 空间 就 可 以 相互 调节 ， 充 分 共 


分 别 设 在 了 存储 空间 的 两 端 ， 栈 项 各 


享 所 有 的 存储 空间 ， 互 补 余 缺 ， 上 只 有 在 整个 存储 空间 被 占 满 时 ， 才 会 发 生 上 溢 ， 这 样 产生 上 


溢 的 概率 要 小 得 多 。 所 以 ， 选 项 A 正确 。 


如 果 采 用 选项 B 或 者 选项 C 的 方案 ， 相 当 于 把 数组 平均 分 配给 两 个 栈 ， 各自 有 独立 的 存 
储 空间 ， 即 使 当 栈 s2 为 空 的 时 候 ， 栈 sl 最 多 能 存放 的 元 素 个 数 为 n02。 所 以 ， 选 项 B、 选 项 


C 错误 。 


对 于 选项 D，sl 的 栈 底 位 置 ; 


所 以 ， 本 题 的 答案 为 A。 
3. 答案 : B。 


正确 ， 所 以 ， 选 项 D 错误 。 


分 析 : 本 题 考察 的 是 对 守护 线程 的 理解 。 


Java 语言 提供 了 两 种 线程 ; 


所 有 非 守护 线程 的 保姆 。 


守护 线程 (Daemon Thread) 与 用 户 线程 。 守 护 线程 又 被 称 为 
“服务 进程 ”“ 精 灵 线 程 ” 或 “后 台 线 程 ” 
程 ， 这 种 线程 并 不 属于 程序 中 不 可 或 缺 的 部 分 。 通 俗 讲 ， 任 何 一 个 守护 线程 都 是 整个 JVM 中 


是 指 当 程序 运行 时 ， 在 后 台 提 供 一 种 通用 服务 的 线 


用 户 线 程 和 守护 线程 几乎 一 样 ， 唯 一 的 不 同 之 处 就 在 于 : 如 果 用 户 线程 已 经 全 部 退出 


运行 ， 只 剩 下 守护 线程 存在 ，JVM 也 就 退出 了 。 因 为 当 所 有 的 非 守 护 线程 结束 时 ， 没 有 了 


被 守护 者 ， 守 护 线程 也 就 没有 工作 可 做 ， 也 就 没有 继续 运行 程序 的 必要 了 ， 程 序 也 就 终止 
也 就 是 说 ， 只 要 有 任何 非 守护 线程 还 在 运行 ， 程 序 就 不 会 


了 ， 同 时 会 杀 死 所 有 和 守护 线程 。 


终止 


在 Java 语言 中 ， 守 护 线程 
编写 程序 时 也 可 以 自己 设置 守护 线 种 


般 上 共有 较 低 的 优先 级 ， 它 并 非 只 由 JVM 内 部 提供 ， 用 户 在 
例如 ， 将 一 个 用 户 线程 设置 为 守护 线程 的 方法 就 是 在 


调用 start 启动 线程 之 前 调用 对 象 的 setDaemon(true) 方 法 ， 如 果 将 以 上 参数 设置 为 false， 则 表 


示 的 是 用 户 进程 模式 。 需 要 注意 的 是 ， 当 在 一 个 守护 线程 中 产生 了 其 他 线程 ， 那 么 这 些 新 产 


生 的 线程 默认 还 是 守护 线程 ， 用 户 线程 也 是 如 此 。 所 以 ， 选 项 B 正确 。 


所 以 ， 本 题 的 答案 为 B。 


4. 答案 : D。 


分 析 : 本 题 考察 的 是 对 序列 化 的 理解 。 
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Java 序列 化 指 的 是 把 Java 对 象 转换 为 字 节 序列 的 过 程 , 而 Java 反 序列 化 指 的 是 把 字 节 序 
列 恢复 为 Java 对 象 的 过 程 。 由 于 Java 语言 在 序列 化 的 时 候 不 会 序列 化 static 变量 ， 因 此 ， 上 
述 代码 只 实例 化 了 变量 word， 而 没有 实例 化 变量 i。 所 以 ， 在 反 序 列 化 的 时 候 ， 只 能 读 取 到 
变量 word 的 值 ， 而 变量 i 的 值 仍然 为 默认 值 ， 该 默认 值 为 0。 所以，word 的 值 为 “123” i 
的 值 为 0， 选项 D 正确 。 

所 以 ， 本 题 的 答案 为 D。 

5. 答案 : D。 

分 析 : 本 题 考察 的 是 对 JDBC 的 理解 。 

本 题 中 ， 对 于 选项 A，Statement 是 Java 语言 执行 数据 库 操 作 的 一 个 重要 方法 ， 用 于 
在 已 经 建立 数据 库 连 接 的 基础 上 ， 向 数据 库 发 送 要 执行 的 SQL 语句 ， 并 返回 它 所 生成 结 
果 的 对 象 ， 每 次 执行 SQL 语句 时 ， 数 据 库 都 要 编译 该 SQL 语句 。 以 下 是 一 个 最 简单 的 SQL 


语句 : 


Statement stmt = conn.getStatement( ); 
stmt.executeUpdate("insert into client values(‘aa’, ‘aaaa’)"); 


所 以 ， 选 项 A 错误 。 
对 于 选项 B，CallableStatement 提供 了 用 来 调用 数据 库 中 存储 过 程 的 接口 。 所 以 , 选项 B 
普 误 。 

对 于 选项 C，PreparedStatement 表示 预 编译 的 SQL 语句 的 对 象 , 用 于 执行 带 参 数 的 预 编 
译 SQL 语句 。 所 以 ， 选 项 C 错误 。 

对 于 选项 D， 不 存在 BatchedStatement 方法 。 所 以 ， 选 项 D 正确 。 

所 以 ， 本 题 的 答案 为 D。 

6. 答案 : A、B、E。 

分 析 : 本 题 考 察 的 是 对 关键 字 final 的 理解 。 

在 Java 语言 中 ， 被 final 关键 字 修饰 的 类 是 不 能 被 继承 的 ， 由 于 Double 和 Math 都 是 被 final 
修饰 的 类 ,因此 , 它们 不 能 被 继承 。 所 以 , 选项 C 和 选项 DD 错误 。Thread、Number 和 ClassLoader 
都 没有 被 final 修饰 ， 因 此 ， 可 以 被 继承 。 所 以 ， 选 项 A、 选项 B 以 及 选项 E 正确 。 

所 以 ， 本 题 的 答案 为 A、B、E。 

7. 答案 : A、B、C、D。 

分 析 : 本 题 考察 的 是 对 网 页 跳 转 的 理解 。 

在 设计 Web 应 用 程序 时 ， 经 常 需要 把 一 个 系统 进行 结构 化 设计 ， 即 按照 模块 进行 划 
分 ， 让 不 同 的 Servlet 来 实现 不 同 的 功能 ， 例 如 可 以 让 其 中 一 个 Servlet 接收 用 户 的 请 求 ， 
另外 一 个 Servlet 来 处 理 用 户 的 请 求 。 为 了 实现 这 种 程序 的 模块 化 ， 就 需要 保证 在 不 同 的 
Servlet 之 间 可 以 相互 跳 转 , 而 Servlet 中 主要 有 两 种 实现 跳 转 的 方式 :forward 方式 与 redirect 

forward 是 服务 器 内 部 的 重 定向 ， 服 务 器 直接 访问 目标 地 址 的 URL， 把 那个 URL 的 响应 
内 容 读 取 过 来 ， 而 客户 端 并 不 知道 ， 因 此 ， 在 客户 端 浏览 器 的 地 址 栏 中 不 会 显示 转向 后 的 地 
址 ， 还 是 原来 的 地 址 。 由 于 在 整个 定向 的 过 程 中 用 的 是 同一 个 Request， 因 此 ，forward 会 将 
Request 的 信息 带 到 被 定 问 的 JSP 或 Servlet 中 使 用 。 
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redirect 则 是 客户 端 重 定向 ， 是 完全 的 跳 转 ， 即 客户 端 浏览 器 会 获取 到 跳 转 后 的 地 址 ， 然 
后 重新 发 送 请 求 ， 因 此 ， 浏 览 器 中 会 显示 跳 转 后 的 地 址 。 同 时 ， 由 于 这 种 方式 比 forward 方式 
多 了 一 次 网 络 请 求 ， 所 以 ，forward 效率 更 高 。 需 要 注意 的 是 ， 客 户 端 重 定向 可 以 通过 设置 特 


定 的 HTTP 头 或 者 写 JavaScript 脚本 实现 。 如 图 30 所 示 。 


Server 


1. Request 1. Request 


Client 一 2 sendRedirect 


Servletl 


Client 


2. forward 


3. new Request— 


图 30 ”forward 方式 与 redirect 方式 


鉴于 以 上 区 别 ， 一 般 情况 下 ， 当 forward 方式 可 以 满足 需求 时 ， 尽 可 能 地 使 用 forward 方 
式 。 但 在 有 些 情况 下 ,， 例 如， 需要 跳 转 到 一 个 其 他 服务 器 上 的 资源 ， 则 必须 使 用 redirect 方式 。 


所 以 ， 选 项 A、 选 项 B、 选 项 C 及 选项 D 正确 。 
所 以 ， 本 题 的 答案 为 A、B、C、D。 
8. 答案 : B。 


分 析 : 本 题 考察 的 是 对 字符 串 的 理解 。 


在 Java 语言 中 ，equals 方法 是 类 Object 中 的 方法 ， 因 此 ， 对 于 所 有 继承 于 Object 的 类 中 


都 会 有 该 方法 。 在 Object 类 中 ，equals 方法 的 作用 是 比较 两 个 对 象 的 引用 是 否 相 等 ， 


指向 同一 个 对 象 。 它 等 价 于 “== ”操作 。 当 这 两 个 引用 指向 同一 个 对 象 的 引用 时 ， 返 


即 是 否 


回 true， 


和 否则， 返回 包 lse。 而 String 类 重 写 了 equals 方法 ，String 类 的 equals 方法 用 来 判断 两 个 引用 


指向 的 字符 串 的 内 容 是 否 相 等 ， 如 果 相等 ， 则 返回 tue， 和 否则， 返回 false。 


对 于 选项 A， 字 符 串 s 和 字符 串 t 的 内 容 相同 ， 都 为 “hello”， 因此， 返回 值 为 tue。 所 


以 ， 选 项 A 错误 。 


对 于 选项 B，t 是 String 的 对 象 ， 而 c 是 字符 数组 的 引用 。equals 方法 的 参数 为 String 类 
型 ， 因 此 ， 会 默认 调用 e 的 toString 方法 ， 这 个 方法 会 返回 c 对 象 的 信息 ， 而 不 是 “hello”， 


因此 ， 返 回 值 为 false。 所 以 ， 选 项 B 正确 。 


对 于 选项 C,，t 的 内 容 与 新 创建 出 来 的 字符 串 的 内 容 都 是 “hello”， 因 此 ， 返 回 值 为 true。 


所 以 ， 选 项 C 错误 。 


对 于 选项 D， 对 于 String 类 的 对 象 而 言 ， 判 等 符 “一 ”通常 用 来 表示 两 个 字符 串 对 象 的 
引用 是 否 相等 。 在 执行 语句 String s="hello" 的 时 候 ， 会 首先 在 常量 区 里 存储 字符 串 “hello”， 


而 s 指向 这 个 对 象 ， 在 执行 语句 String {="hello" 的 时 候 ， 由 于 在 常量 区 里 已经 存在 这 个 字符 串 
了 ， 因 此 , t 也 直接 指向 这 个 字符 串 ， 而 不 会 去 创建 新 的 字符 串 ， 字 符 串 s 与 字符 串 的 值 相 


等 。 所 以 ，s 一 :t 的 返回 值 为 tue， 选 项 D 错误 。 
所 以 ， 本 题 的 答案 为 B。 


二 、 简 答题 


1. 答案 : SUN 公司 对 Java 语言 的 描述 如 下 : “Javais a simple, object-oriented, distributed, 


302 


真题 详解 篇 


interpreted, robust, secure, architecture neutral, portable, high-performance, multithreaded, and 
dynamic language”。 具 体 而 言 ，Java 语言 具有 以 下 几 个 方面 的 优点 : 

1) Java 为 纯 面 问 对 象 的 语言 〈《Java 编程 思想 》 提 到 Java 语言 是 一 种 “Everything is 
object” 的 语言 )， 它 能 够 直接 反映 现实 生活 中 的 对 象 ， 例 如 火车 、 动 物 等 ， 因 此 ， 通 过 它 ， 
开发 人 员 更 容易 编写 程序 。 

2) 平台 无 关 性 。Java 语言 可 以 一 次 编译 ， 到 处 运行 。 无 论 是 在 Windows 平台 还 是 在 
Linux、MacOS 等 其 他 平台 上 对 Java 程序 进行 编译 ,编译 后 的 程序 在 其 他 平台 上 都 可 以 运行 。 
由 于 Java 为 解释 型 语言 ， 编 译 器 会 把 Java 代码 变 成 “中 间 代 人 码 ” 然后 在 JVM (Java Virtual 
Machine，Java 虚拟 机 ) 上 解释 执行 。 由 于 中 间 代 码 与 平台 无 关 ， 所 以 ，Java 语言 可 以 很 好 地 
跨 平台 执行 ， 具 有 很 好 的 可 移植 性 。 

3) Java 提供 了 很 多 内 置 的 类 库 ， 这 些 类 库 简 化 了 开发 人 员 的 程序 设计 工作 ， 同 时 缩短 了 
项 目的 开发 时 间 。 例 如 ，Java 语言 提供 了 对 多 线程 支持 ， 提 供 了 对 网 络 通信 的 支持 ， 最 重要 
的 一 点 是 提供 了 垃圾 回收 器 ， 把 开发 人 员 从 对 内 存 的 管理 中 解脱 出 来 。 

4) Java 语言 提供 了 对 Web 应 用 开发 的 文 持 , 例如，Applet、Servlet 和 JSP 可 以 用 来 开发 
Web 应 用 程序 ，Socket、RMI 可 以 用 来 开发 分 布 式 应 用 程序 的 类 库 。 

5) Java 语言 具有 较 好 的 安全 性 和 健壮 性 。Java 语言 经 常 被 用 在 网 络 环境 中 ， 为 了 增强 程 
序 的 安全 性 ，Java 语言 提供 了 一 个 防止 恶意 代码 攻击 的 安全 机 制 ( 数 组 边界 检测 和 byte code 
校 验 等 )。Java 的 强 类 型 机 制 、 垃 圾 回收 器 、 异 常 处 理 和 安全 检查 机 制 使 得 使 用 Java 语言 编 
写 的 程序 有 很 好 的 健壮 性 。 

6) Java 语言 去 除了 C++ 语言 中 难以 理解 、 容 易 混淆 的 特性 ， 例 如 头 文件 、 指 针 、 结 构 、 
单元 、 运 算 符 重 载 、 虚 拟 基 础 类 及 多 重 继承 等 ， 使 得 程序 更 加 严 说、 简洁 。 

2. 答案 : 本 题 考 察 的 是 对 多 线程 同步 的 理解 。 

题 中 的 这 段 代 码 在 大 部 分 情况 下 都 能 正常 运行 ， 但 在 下 面 的 场景 中 会 有 问题 

在 多 线程 访问 这 个 栈 的 时 候 ， 如 果 有 三 个 线程 按照 如 下 的 顺序 访问 ， 问 题 就 会 暴露 。 

1) 线程 1 先 执行 pop 操作 ， 此 时 ， 由 于 list 的 大 小 为 0， 因 此 ， 会 调用 wait 释放 
等 待 锁 。 

2) 线程 2 执行 push 操作 ， 往 队列 里 放 了 一 个 元 素 ， 这 个 线程 会 调用 notify 来 唤醒 等 待 
的 线程 。 

3) 就 在 此 时 恰好 另外 一 个 线程 3 也 执行 pop 操作 ， 此 时 线程 1 和 线程 3 的 执行 顺序 是 无 
法 保证 的 。 如 果 恰 好 线程 3 先 执 行 pop 操作 ， 执 行 完成 后 ， 线 程 2 被 唤醒 ， 此 时 线程 2 会 执 
行 return stack.remove(stack.sizeO-]) 操 作 ， 由 于 此 时 队列 已 经 为 空 ，stack.size0 的 返回 值 为 0， 
所 以 ， 程 序 会 抛 出 java.lang.ArrayIndexOutOfBoundsException 异常 。 

以 上 问题 的 解决 方法 也 很 简单 ， 即 在 pop 操作 调用 remove 方法 前 再 进行 一 次 判断 ， 判 断 
列表 里 是 否 还 有 元 素 ， 实 现代 码 如 下 : 


public synchronized String pop() throws InterruptedException 


{ 
synchronized(this) 
{ 


if(stack.size()<=0) 
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{ 
wait(); 
} 
if(stack.size()<=0) 
return null; 
else 
return stack.remove(stack.size()-1); 


Sub.num=0 
Sub.num = 3 
2 

分 析 : 本 题 考察 的 是 对 Java 类 中 初始 化 的 顺序 以 及 多 态 的 理解 。 

Java 程序 初始 化 工作 可 以 在 许多 不 同 的 代码 块 中 来 完成 (例如 静态 代码 块 、 构 造 函数 等 )， 

它们 执行 的 顺序 如 下 : 父 类 静态 变量 、 父 类 静态 代码 块 、 子 类 静态 变量 、 子 类 静态 代码 块 、 
父 类 非 静态 变量 、 父 类 非 静 态 代码 块 、 父 类 构造 函数 、 子 类 非 静 态 变量 、 子 类 非 静态 代码 块 
及 子 类 构造 函数 。 
1 于 子 类 可 以 覆盖 父 类 的 方法 ， 因 此 ， 同 样 的 方法 会 在 父 类 与 子 类 中 有 着 不 同 的 表现 形 
式 。 在 Java 语言 中 ， 基 类 的 引用 变量 不 仅 可 以 指向 基 类 的 实例 对 象 ， 也 可 以 指向 其 子 类 的 实 
例 对 象 。 同 样 ， 接 口 的 引用 变量 也 可 以 指向 其 实现 类 的 实例 对 象 。 而 程序 调用 的 方法 在 运行 
期 才 动 态 绑 定 〈 绑 定 指 的 是 将 一 个 方法 调用 和 一 个 方法 主体 连接 到 一 起 )， 就 是 引用 变量 所 指 
向 的 具体 实例 对 象 的 方法 ， 也 就 是 内 存 里 正在 运行 的 那个 对 象 的 方法 ， 而 不 是 引用 变量 的 类 
型 中 定义 的 方法 。 通 过 这 种 动态 绑 定 的 方法 实现 了 多 态 。 需 要 注意 的 是 ， 只 有 方法 有 多 态 的 
概念 ， 属 性 是 没有 多 态 的 概念 的 。 

对 于 本 题 而 言 ， 在 执行 语句 Base b = new Sub0 时 ， 会 首先 调用 父 类 的 构造 方法 ， 而 在 父 
类 构造 方法 中 调用 print(0 方 法 。 根 据 多 态 的 特性 ， 此 时 实际 上 实例 化 的 是 Sub 类 的 对 象 ， 
此 ， 会 调用 Sub 类 的 print 方法 。 由 于 此 时 Sub 类 中 的 初始 化 代码 intnum = 3 还 没有 执行 ， 
此 ，num 的 默认 值 为 0， 所 以 ， 输 出 为 Sub.num = 0， 然 后 把 父 类 的 num 初始 化 为 2。 接着 
调用 子 类 的 构造 方法 ， 根 据 初 始 化 的 顺序 可 知 ， 在 调用 子 类 构造 方法 时 ， 非 静态 的 变量 会 先 
执行 初始 化 动作 , 所 以 , 此 时 子 类 Sub 的 num 的 值 为 3, 因此 , 调用 print 方法 会 输出 Sub.num 
=3。 接 着 输出 bnum， 由 于 的 类 型 为 Base， 而 属性 没有 多 态 的 概念 。 因 此 ， 此 时 会 输出 父 
类 中 的 num 的 值 : 2。 

4. 答案 :本题 考 察 的 是 设计 模式 的 知识 。 

以 下 将 重点 分 析 工 三 模式 、 适 配器 模式 以 及 观察 者 模式 的 内 容 。 

(1) 工厂 模式 

工厂 模式 专门 负责 实例 化 有 大 量 公共 接口 的 类 。 工 厂 模式 可 以 动态 地 决定 将 哪 一 个 类 实 
例 化 ， 而 不 必 事 先知 道 每 次 要 实例 化 哪 一 个 类 。 客 户 类 和 工厂 类 是 分 开 的 ， 消 费 者 无 论 什么 
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时 候 需 要 某 种 产品 ， 需 要 做 的 只 是 向 工厂 提出 请 求 即 可 。 消 费 者 无 须 修改 就 可 以 接纳 新 产品 ， 
当然 ， 该 模式 也 存在 缺点 ， 就 是 当 产 品 修改 时 ， 工 厂 类 也 要 做 相应 的 修改 。 
工厂 模式 包含 以 下 儿 种 形态 : 


1) 简单 工厂 (Simple Factory) 模式 。 简 单 工厂 模式 的 工厂 类 是 根据 提供 给 它 的 参数 ， 返 
回 几 个 可 能 产品 中 的 一 个 类 的 实例 ， 通 常情 况 下 ， 它 返回 的 类 都 有 一 个 公共 的 父 类 和 公共 的 
方法 。 设 计 类 图 如 图 31 所 示 。 


人 


ConcreteProduct1 ConcreteProduct2 


图 31 简单 工厂 模式 设计 类 多 


其 中 ，Product 为 待 实例 化 类 的 基 类 ， 它 可 以 有 多 个 子 类 ;SimpleFactory 类 中 提供 了 实例 
化 Product 的 方法 ， 这 个 方法 可 以 根据 传 入 的 参数 动态 地 创建 出 某 一 类 型 产品 的 对 象 。 

2) 工厂 方法 (Factory Method) 模式 。 工 三 方法 模式 是 类 的 创建 模式 ， 其 用 意 是 定义 一 
个 用 于 创建 产品 对 象 的 工厂 接口 ， 而 将 实际 创建 工作 推迟 到 工厂 接口 的 子 类 中 ， 它 属于 简单 
工厂 模式 的 进一步 抽象 和 推广 。 多 态 的 使 用 ， 使 得 工矿 方法 模式 保持 了 简单 工厂 模式 的 优点 ， 
而 且 克 服 了 它 的 缺点 。 设 计 类 图 如 图 32 所 示 。 


八 


Creator 


+createProduct () 
+otherProductOp() 


八 


ConcreteProduct ConcreteCreator 


图 32 工厂 方法 模式 设计 类 轿 


Product 为 产品 的 接口 或 基 类 ， 所 有 的 产品 都 实现 这 个 接口 或 抽象 类 【例如 
ConcreteProduct)， 这 样 就 可 以 在 运行 时 根据 需求 创建 对 应 的 产品 类 。Creator 实现 了 对 产品 所 
有 的 操作 方法 ， 而 不 实现 产品 对 象 的 实例 化 。 产 品 的 实例 化 由 Creator 的 子 类 来 完成 。 

3) 抽象 工厂 〈Abstract Factory) 模式 。 抽 人 象 工厂 模式 是 所 有 形态 的 工厂 模式 中 最 为 抽象 
和 最 具 一 般 性 的 一 种 形态 。 抽 象 工厂 模式 是 指 当 有 多 个 抽象 角色 时 使 用 的 一 种 工厂 模式 ， 抽 


305 


Java 程序 员 面 试 笔试 真题 库 


象 工厂 模式 可 以 向 客户 端 提供 一 个 接口 ， 使 客户 端 在 不 必 指定 产 品 的 具体 的 情况 下 ， 创 建 多 
个 产品 族 中 的 产品 对 象 。 根 据 LSP 原则 〈 即 Liskov 蔡 换 原则 )， 任 何 接受 父 类 型 的 地 方 ， 都 
应 当 能 够 接受 子 类 型 。 因 此 ， 实 际 上 系统 所 需要 的 ， 仅 仅 是 类 型 与 这 些 抽象 产品 角色 相同 的 
一 些 实例 ， 而 不 是 这 些 抽象 产品 的 实例 。 换 句 话 说， 也 就 是 这 些 抽象 产品 的 具体 子 类 的 实例 。 
工厂 类 负责 创建 抽象 产品 的 其 体 子 类 的 实例 。 设 计 类 图 如 图 33 所 示 。 


ConcreteProductA2 


+CreateProductA() | 
+CreateProductB() : 


ConcreteFactoryl 


+CreateProductA() 
+CreateProductB () 


ConcreteProductAl 


ConcreteProductB2 


ConcreteProductB1 


图 33 ”抽象 工厂 模式 设计 类 图 


AbstractProductA 和 AbstractProductB 代表 一 个 产品 家 族 ， 实 现 这 些 接口 的 类 代表 具体 的 
产品 。AbstractFactory 为 创建 产品 的 接口 ， 能 够 创建 这 个 产品 家 族 中 的 所 有 类 型 的 产品 ， 它 的 
子 类 可 以 根据 有 具体 情况 创建 对 应 的 产品 。 

(2) 适配器 模式 
适配器 模式 也 称 为 变压器 模式 , 它 是 把 一 个 类 的 接口 转换 成 客户 端 所 期 望 的 另 一 种 接口 ， 
从 而 使 原本 因 接 口 不 匹配 而 无 法 一 起 工作 的 两 个 类 能 够 一 起 工作 。 适 配 类 可 以 根据 所 传递 的 
参数 返回 一 个 合适 的 实例 给 客户 端 。 
适配器 模式 主要 应 用 于 “希望 复 用 一 些 现 存 的 类 ， 但 是 接口 又 与 复 用 环境 要 求 不 一 致 
的 情况 ” 在 遗留 代码 复 用 、 类 库 迁 移 等 方面 非常 有 有 用。 同时， 适配器 模式 有 对 象 适配器 
和 类 适配器 两 种 形式 的 实现 结构 ， 但 是 类 适配器 采用 “多 继承 ”的 实现 方式 ， 会 引起 程序 
的 高 耦合 ， 所 以 ， 一 般 不 推荐 使 用 ;而 对 象 适 配器 采用 “对 和 象 组 合 ” 的 方式 ， 耦 合 度 低 ， 
应 用 范围 更 广 。 

例如 ， 现 在 系统 里 已 经 实现 了 点 、 线 及 正方 形 ， 而 现在 客户 要 求实 现 一 个 圆 形 ， 一 般 的 
做 法 是 建立 一 个 Circle 类 来 继承 以 后 的 Shape 类 ， 然 后 去 实现 对 应 的 display、fill 和 undisplay 
等 方法 。 此 时 ， 如 果 发 现 项 目 组 其 他 人 已 经 实现 了 一 个 画 圆 的 类 ， 但 是 他 的 方法 名 和 自己 的 
不 一 样 ， 为 displayhh、fillhh、undisplayhh， 不 能 直接 使 用 这 个 类 ， 因 为 那样 无 法 保证 多 态 ， 
而 有 的 时 候 ， 也 不 能 要 求 组 件 类 改写 方法 名 ， 此 时 ， 可 以 采用 适配器 模式 。 设 计 类 图 如 图 34 
所 示 。 
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访问 适配器 的 客户 端 程序 图 客户 端 期 望 看 到 的 接口 
“interface>> 
| Terset 
[| SE 


实际 存在 的 接 


\ 
把 用 户 期 望 的 接口 转换 为 实际 存在 的 接口 的 调 | | | | 
| | 


图 34 ”适配器 模式 设计 类 图 


(3) 观察 者 模式 

观察 者 模式 〈 也 被 称 为 发 布 /订阅 模式 ) 提供 了 避免 组 件 之 间 紧 密 耦合 的 另 一 种 方法 ， 
它 将 观察 者 和 被 观察 的 对 和 象 分 离开 。 在 该 模式 中 ,一 个 对 象 通过 添加 一 个 方法 (该 方法 允许 
另 一 个 对 象 ， 即 观察 者 注册 自己 ) 使 本 身 变 得 可 观察 。 当 可 观察 的 对 象 更 改 时 ， 它 会 将 消息 
发 送 到 已 注册 的 观察 者 。 这 些 观 察 者 使 用 该 信息 执行 的 操作 与 可 观察 的 对 象 无 关 , 结果 是 对 
象 可 以 相互 对 话 ， 而 不 必 了 解 原因 。Java 语言 与 C# 语 言 的 事件 处 理 机 制 就 是 采用 的 此 种 设 
计 模 式 。 

例如 ， 用 户 界 面 可 以 作为 一 个 观察 者 ， 业 务 数据 是 被 观察 者 ， 用 户 界 面 观察 业务 数据 
的 变化 ， 当 发 现 数据 变化 后 ， 就 显示 在 界面 上 。 面 向 对 象 设 计 的 一 个 原则 是 : 系统 中 的 每 个 
类 将 重点 放 在 某 一 个 功能 上 ， 而 不 是 其 他 方面 。 一 个 对 象 只 做 一 件 事 情 ， 并 且 将 它 做 好 。 观 
察 者 模式 在 模块 之 间 划 定 了 清晰 的 界限 ， 提 高 了 应 用 程序 的 可 维护 性 和 重用 性 。 设 计 类 图 如 
图 35 所 示 。 


增加 和 删除 观察 者 的 主题 接口 所 有 观察 者 的 接口 


《interface>> 
Subject 《<interface>> 
Observer 


taddObserver () 


tremoveObserver () 
tnotifyObservers () 


ConcretSubject ConcreteObserver 


实现 增加 和 删除 观察 者 ， 实 现 通知 所 有 观察 者 对 象 实际 的 观察 者 


图 35 ”观察 者 模式 设计 类 图 
案 : 本 题 考察 的 是 对 堆 、 栈 和 持久 代 的 理解 。 


[D4] 
I 六 
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1) 在 Java 语言 中 ,通过 new 实例 化 的 对 象 都 存储 在 堆 空 间 中 ， 


因此 ， 只 要 不 断 地 用 new 


实例 化 对 和 象 且 一 直 保 持 对 这 些 对 和 象 的 引用 垃圾 回收 器 无 法 回收 )， 实 例 化 足够 多 的 实例 出 来 


就 会 导致 堆 溢出 ， 示 例 代码 如 下 : 


List<Object> l=new ArrayList<Object>(); 
while(true) 
l.add(new Object()); 


上 面 这 段 代码 会 一 直 不 停 地 创建 Object 的 对 象 ， 


并 存储 在 List 里 面 。 


因为 创建 出 来 的 对 


象 一 直 被 引用 ， 所 以 垃圾 回收 器 无 法 进行 回收 ， 在 创建 一 定 的 数量 后 ， 就 会 出 现 堆 溢出 。 
2) 在 方法 调用 的 时 候 ， 栈 用 来 保存 上 下 文 的 一 些 内 容 。 由 于 栈 的 大 小 是 有 限 的 ， 当 出 现 


非常 深层 次 的 方法 调用 的 时 候 ， 就 会 把 栈 的 名 


上 辣 


j 完 ， 最 简单 的 栈 溢 出 的 代码 就 是 无 限 递归 


调用 ， 示 例 代 人 码 如 下 : 


public class Test 
{ 
public static void f() 
{ 
System.out.println("Hello"); 
f0; 
} 
public static void main(String[] args) 
{ 
f0; 
} 
} 


程序 运行 的 过 程 中 会 不 断 地 输出 
StackOverflowError 异常 。 


“ Hello ”， 


输出 一 会 后 就 会 抛 出 


java.lang. 


3) 持久 代 : 在 Java 语言 中 ， 当 一 个 类 第 一 次 被 访问 的 时 候 ，JVM 需要 把 类 加 载 进来 ， 
而 类 加 载 器 就 会 占用 持久 代 的 空间 来 存储 classes 信息 。 持 久 代 中 主要 包含 以 下 的 信息 : 类 方 


法 、 类 名 、 常 量 池 及 JVM 使 用 的 内 部 对 象 等 。 当 JVM 需要 加 载 一 个 新 的 类 的 时 候 ， 如 果 持 


久 代 中 没有 足够 的 空间 ， 此 时 就 会 所 出 Java.Lang.OutOfMemoryError: PermGen Space 异常 。 


所 以 ， 当 代码 加 载 足够 多 类 的 时 候 就 会 导致 持久 代 溢 出 。 当 然 ， 


有 持久 代 的 概念 。 
6. 答案 : 5 种 。 


分 析 : 本 题 考察 的 是 对 事务 隔离 级 别 的 理 


= 


并 不 是 所 有 的 Java 虚拟 机 都 


必 


为 了 解决 与 “多 个 线程 请 求 相 同 数据 ”相关 的 问题 ， 事 务 之 间 通 常会 用 锁 相 互 隔离 开 。 


现今 , 大 多 数 主流 的 数据 库 支 持 不 同类 型 的 锁 。 因 此 ，JDBC API 文 持 不 同类 型 的 事务 ， 


它们 


由 Connection 对 象 指派 或 确定 。 在 JDBC 中 ， 定 义 了 以 下 5 种 事务 隔离 级 别 : 

1) TRANSACTION NONE JDB: 不 支持 事务 。 

2) TRANSACTION READ_ UNCOMMITTED: 未 提交 读 。 说 明 在 提交 前 一 个 事务 可 以 
看 到 另 一 个 事务 的 变化 。 这 样 读 “及 ”数据 、 不 可 重复 读 和 “ 虚 读 ”都 是 允许 的 。 

3) TRANSACTION READ_ COMMITTED: 已 提交 读 。 说 明 读 取 未 提交 的 数据 是 不 允许 
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的 。 这 个 级 别 仍然 允许 不 可 重复 读 和 “ 虚 读 ”产生 。 

4) TRANSACTION REPEATABLE READ: 可 重复 读 。 说 明 事 务 保 证 能 够 再 次 读 取 相 同 
的 数据 而 不 会 失败 ， 但 “ 虚 读 ”仍然 会 出 现 。 

5) TRANSACTION _SERIALIZABLE: 可 序列 化 。 它 是 最 高 的 事务 级 别 ,， 可 以 防止 读 “ 脏 ” 

数据 、 不 可 重复 读 和 “ 虚 读 ”。 
《备注 : 读 “ 脏 ”数据 指 的 是 一 个 事务 读 取 了 另 一 个 事务 尚未 提交 的 数据 。 例 如 ， 当 事务 
A 与 事务 B 并 发 执行 时 ， 当 事务 A 更 新 后 , 事务 B 查询 读 取 到 事务 A 尚未 提交 的 数据 ， 此 时 
事务 A 回 滚 ， 则 事务 B 读 到 的 数据 是 无 效 的 “ 脏 ” 数 据 。 不 可 重复 读 指 的 是 一 个 事务 的 操作 
导致 另 一 个 事务 前 后 两 次 读 取 到 不 同 的 数据 。 例 如 ， 当 事务 A 与 事务 B 并 发 执行 时 ， 当 事务 
B 查询 读 取 数 据 后 , 事务 A 更 新 操作 更 改 事务 B 查询 到 的 数据 , 此 时 事务 B 再 次 读 取 该 数据 ， 
发 现 前 后 两 次 的 数据 不 一 样 。“ 虚 读 ” 指 的 是 一 个 事务 的 操作 导致 另 一 个 事务 前 后 两 次 查询 的 
结果 数据 量 不 同 。 例 如 ， 当 事务 A 与 事务 B 并 发 执行 时 ， 当 事务 B 查询 读 取 数据 后 ， 事 务 A 
新 增 或 删除 了 一 条 满足 事务 A 的 查询 条 件 的 记录 ， 此 时 ， 事 务 B 再 次 查询 ， 发 现 查 询 到 前 次 
不 存在 的 记录 ， 或 者 前 次 的 某 个 记录 不 见 了 。 以 银行 存款 为 例 ，A 存款 100 元 未 提交 ， 这 时 
银行 做 报表 进行 统计 查询 账户 为 200 元 , 然后 A 提交 了 , 这 时 银行 再 统计 发 现 账户 为 300 元 ， 
无 法 判断 到 底 以 哪个 为 准 ? ) 

7. 答案 : Vector。 

分 析 : 本 题 考 察 的 是 对 容器 的 理解 。 

Hashtable 是 线程 安全 的 ， 而 HashMap 不 是 线程 安全 的 。 

Vector 中 的 绝 大 多 数 的 方法 〈 例 如 add、insert、remove、set、equals 和 Hashcode 等 ) 都 
是 直接 或 者 间接 同步 的 ， 所 以 ，Vector 是 线程 安全 的 。 

TreeSet 实现 了 SortedSet 接口 ， 因 此 ，TreeSet 容器 中 的 元 素 是 有 序 的 ， 但 是 它 不 是 线程 
安全 的 。 

LinkedList 是 采用 双向 列表 来 实现 的 ， 对 数据 的 索引 需要 从 列表 头 开始 遍历 ， 因 此 ， 随 机 
访问 的 效率 比较 低 ， 但 是 插入 元 素 的 时 候 不 需要 对 数据 进行 移动 ， 因 此 ， 插 入 效率 较 高 。 但 
是 LinkedList 不 是 线程 安全 的 。 

8. 答案 : Web 服务 器 指 的 是 提供 Web 功能 的 服务 器 ， 主 要 就 是 HTTP 服务 器 ， 包 括 图 
片 的 下 载 等 一 系列 和 文本 相关 的 内 容 。Web 服务 器 文 持 以 HTTP 协议 的 方式 来 访问 ， 当 Web 
服务 器 接收 到 一 个 HTTP 请 求 时 ， 它 同样 会 以 HTTP 协议 格式 返回 一 个 响应 ， 这 个 响应 可 以 
是 一 个 静态 的 HTML 页 面 ， 也 可 以 是 经 过 处 理 的 一 个 动态 的 页 面 ， 还 可 以 是 音频 、 视 频 等 信 
息 。 为 了 处 理 一 个 请 求 ，Web 服务 器 可 以 做 出 一 个 响应 ， 并 进行 页 面 跳 转 ， 或 者 把 动态 响应 
的 产生 委托 给 一 些 其 他 的 程序 ， 例 如 CGI 脚本 、JSP、Servlet 或 者 一 些 其 他 的 服务 器 端 程序 。 
Web 服务 器 一 般 都 使 用 了 一 些 特有 的 机 制 ( 例 如 容错 机 制 ) 来 保证 Web 服务 器 有 较 好 的 扩展 
性 和 不 间断 地 提供 服务 。 常 见 的 Web 服务 器 有 IIS 和 Apache。 

应 用 服务 器 提供 访问 业务 逻辑 的 途径 以 供 客 户 端 应 用 程序 使 用 ,具体 而 言 , 它 通 过 HTTP、 
TCP/IP、IIOP (Internet Inter-ORB Protocol， 互 联网 内 部 对 和 象 请 求 代理 协议 ) 或 JRMP (Java 
Remote Method Protocol，Java 远程 方法 协议 ) 等 协议 来 提供 业务 逻辑 接口 。 为 了 系统 的 可 靠 
性 ， 同 样 使 用 了 一 些 可 扩展 性 和 容错 机 制 。 除 此 之 外 ， 它 还 为 应 用 的 开发 提供 了 许多 服务 ， 
例如 事务 管理 、 安 全 管理 及 对 象 生命 周期 管理 等 。 常见 的 应 用 服务 器 有 BEA WebLogic Server、 
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IBM WebSphere Application Server、IPlanet Application Server、Oracle91 Application Server、JBoss 
和 Tomcat 等 。 

Web 服务 器 一 般 是 通用 的 ， 而 应 用 服务 器 一 般 是 专用 的 ， 例 如 Tomcat 只 能 处 理 Java 应 
用 程序 而 不 能 处 理 ASPX 或 PHP。 需 要 注意 的 是 ，Web 服务 器 与 应 用 服务 器 是 并 列 关 系 ， 二 
者 不 存在 相互 包容 关系 。 在 使 用 的 时 候 ， 如 果 访 问 的 页 面具 有 HIML， 用 Web 服务 器 就 足够 
了 ， 但 是 如 果 是 JSP， 此 时 就 需要 应 用 服务 器 ， 因 为 只 有 应 用 服务 器 才能 解析 JSP 里 的 Java 
代码 ， 并 将 解析 结果 以 HTML 的 格式 返回 给 用 户 。 


ia 是 | 某 著名 社交 类 上 市 公司 软件 工程 师 笔 试题 


一 、 填 空 题 

1. 答案 : 继承 ， 封 装 ， 多 态 。 

2. 答案 : JSP 共有 9 个 内 置 对 象 ， 分 别 为 request、response、out、session、page、application、 
exception、config 和 pageContext。 
， 答案 : List 和 Set 继承 自 Collection 接口 ，Map 不 是 。 
. 答案 : 原子 性 ， 一 致 性 ， 隔 离 性 ， 持 和 久 性 。 


.答案 : altertable table_ name add column name datatype。 


- 了 
| 


Li 
pa 


1. 答案 : D、E。 

分 析 : 本 题 考 察 的 是 对 抽象 类 的 理解 。 

被 声明 为 abstract 的 类 为 抽象 类 ， 由 于 抽象 类 中 存在 没有 方法 体 的 方法 ， 因 此 ， 它 不 能 被 
实例 化 ， 只 有 实现 了 抽象 方法 的 子 类 才能 被 实例 化 。 所 以 ， 选 项 A 和 选项 B 错误 。 

abstract 类 的 子 类 可 以 是 abstract， 此 时 子 类 就 无 法 实例 化 ，abstract 类 的 子 类 也 可 以 不 是 
abstract， 此 时 子 类 可 以 被 实例 化 。 所 以 ， 选 项 C 错误 ， 选 项 E 正确 。 

对 于 选项 D， 对 于 一 个 声明 为 abstract 的 类 ， 由 于 无 法 实例 化 ， 如 果 要 想 使 用 它 ， 那 么 必 
须 继 承 这 个 类 并 实现 抽象 方法 ， 所 以 ， 选 项 D 正确 。 

所 以 ， 本 题 的 答案 为 D、E。 

2. 答案 : G。 

分 析 : 本 题 考察 的 是 对 判 等 符 “==” 和 equals 的 理解 。 

在 Java 语言 中 ， 判 等 符 “==” 用 来 比较 对 象 的 地 址 是 否 相 同 ， 进 行 比 较 的 对 和 象 必 须 是 类 
型 相同 的 对 象 ， 对 于 本 题 而 言 ， 变 量 i、1 和 d 是 不 同类 型 的 对 象 ， 因 此 ， 在 使 用 判 等 符 “==” 
比较 的 时 候 ， 编 译 器 会 报错 。 因 此 ， 选 项 A、 选 项 B 和 选项 C 错误 。 

equals 方法 用 来 比较 对 象 的 值 是 否 相 同 。Integer 类 的 equals 方法 的 描述 为 : 只 有 当 参 数 
不 为 null 而 且 参 数 为 Integer 类 型 且 有 相同 的 int 值 的 时 候 ， 才 返回 true， 和 否则 ， 返 回 false。 
Long 类 与 Double 类 的 equals 方法 的 描述 类 似 。 

对 于 选项 D、 选 项 玉 和 选项 FE， 调 用 方法 的 对 象 与 参数 的 类 型 都 不 相同 ， 因 此 ， 返 回 值 
为 false。 所 以 ， 选 项 D、 选 项 E 和 选项 下 错误 。 

对 于 选项 G， 对 象 1 的 类 型 为 Long， 而 4L 的 类 型 也 为 Long， 它 们 有 相同 的 值 ， 因 此 ， 
返回 值 为 rue。 所 以 ， 选 项 G 正确 。 
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所 以 ， 本 题 的 答案 为 G。 


3. 答案 : D。 
分 析 : 本 题 考察 的 是 对 前 置 自 增 运 算 符 ++ 和 后 置 自 增 运算 符 ++ 的 理解 。 


前 置 自 增 运 算 符 ++ 与 后 置 自 增 运 算 符 ++ 有 本 质 的 区 别 , 它们 的 相同 点 都 是 为 自身 加 了 1， 
不 同 点 是 前 置 自 增 运 算 符 ++ 是 先 加 1， 再 使 用 操作 数 的 值 ， 后 置 自 增 运算 符 ++ 是 先 使 用 操作 
数 的 值 ， 再 加 1。 

本 题 中 ， 在 执行 语句 x=++x*y 的 时 候 ， 首 先 ， 变 量 x 的 值 变 为 9， 然后 乘 以 y，y 的 值 为 
2, 得 到 x 的 值 为 18, 在 执行 语句 z=x/y++ 的 时 候 , 首先 会 执行 z=x/y, 运算 结束 后 再 执行 y++， 
所 以 ， 运 行 结束 后 y 的 值 为 3。 所 以 ， 选 项 D 正确 。 

所 以 ， 本 题 的 答案 为 D。 

4. 答案 : A。 

分 析 : 本 题 考 察 的 是 对 线程 同步 的 理解 。 

对 于 选项 A， 同 步 就 是 协同 步调 ， 按 预定 的 先后 次 序 进行 运行 。 例 如 ， 你 说 完 ， 我 再 说 。 
该 定义 正好 与 题目 描述 一 致 。 所 以 ， 选 项 A 正确 。 

对 于 选项 B， 假 设计 算 机 的 CPU 在 任意 时 刻 都 上 只 能 执行 一 条 机 器 指令 ， 线 程 只 有 获得 
CPU 的 使 用 权 才 能 执行 对 应 的 操作 ,多 线程 的 并 发 运行 原理 为 : 各 个 线程 轮流 获得 CPU 的 使 
用 权 , 来 执行 对 应 的 操作 。 线程 调度 是 指 按 照 特定 机 制 为 多 个 线程 分 配 CPU 的 使 用 权 。 所 以 ， 
选项 B 错误 。 

对 于 选项 C， 线 程 有 多 个 状态 ， 就 绪 是 指 这 个 线程 已 经 有 了 除 CPU 外 所 有 的 资源 ， 在 等 
待 获取 CPU， 一 旦 获取 到 CPU 的 控制 权 就 可 以 立即 执行 。 所 以 ， 选 项 C 错误 。 

对 于 选项 D， 线 程 互 斥 是 指 某 一 资源 同时 只 允许 一 个 访问 者 对 其 进行 访问 ， 具 有 唯 
性 和 排 它 性 。 但 互 斥 无 法 限制 访问 者 对 资源 的 访问 顺序 ， 即 访问 是 无 序 的 。 所 以 ， 选 项 D 
彰 误 。 

所 以 ， 本 题 的 答案 为 A。 

5. 答案 : D。 

分 析 : 本 题 考察 的 是 对 访问 权限 修饰 符 的 理解 。 

在 Java 语言 中 ， 默 认 访 问 权 限 是 指 没有 指定 访问 权限 的 情况 时 的 访问 权限 。 在 这 种 情况 
下 ， 类 中 的 属性 和 方法 可 以 被 同一 个 包 内 的 类 访问 。 所 以 ， 选 项 DD 正确 。 

所 以 ， 本 题 的 答案 为 D。 

三 、 问 答题 

1. 答案 : 语句 二 i++ 不 是 线程 安全 的 。 

本 题 中 ， 语 句 i++ 的 执行 过 程 如 下 : 先 把 i 的 值 取出 来 放 到 栈 顶 ， 可 以 理解 为 3 引入 了 一 
个 第 三 方 变量 k， 此 时 , k 的 值 为 i， 然 后 执行 自 增 操作 ， 于 是 i 的 值 变 为 1， 最 后 执行 赋值 操 
作 二 k《〈 自 增 前 的 值 )， 因 此 ， 执 行 结束 后 ，i 的 值 还 是 0。 从 上 面 的 分 析 可 知 ， 二 it+ 语 句 的 执 
行 过 程 由 多 个 操作 组 成 ， 它 不 是 原子 操作 ， 因 此 ， 它 不 是 线程 安全 的 。 

在 Java 语言 中 ，++i 和 i++ 操作 并 不 是 线程 安全 的 ， 在 使 用 的 时 候 ， 不 可 避免 地 会 用 到 
synchronized 关键 字 。 而 AtomicInteger 是 一 个 提供 原子 操作 的 Integer 的 类 ， 它 提供 了 线程 安 
全 且 高 效 的 原子 操作 , 是 线程 安全 的 , 其 底层 的 原理 是 利用 处 理 器 的 CASCCompare And Swap， 
比较 与 交换 ， 一 种 有 名 的 无 锁 算 法 ) 操作 来 检测 栈 中 的 值 是 否 被 其 他 线程 改变 ， 如 果 被 改变 ， 
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则 CAS 操作 失败 。 这 种 实现 方法 在 CPU 指令 级 别 实 现 了 原子 操作 ， 因 此 ， 它 比 使 用 
Synchronized 来 实现 同步 效率 更 高 。 

CAS 操作 过 程 都 包含 三 个 运算 符 : 内 存 地 址 V、 期 望 值 A 和 新 值 B。 当 操作 的 时 候 ， 如 
果 地 址 V 上 存放 的 值 等 于 期 望 值 A， 则 将 地 址 V 上 的 值 赋 为 新 值 B， 和 否则 ， 不 做 任何 操作 ， 
但 是 要 返回 原 值 是 多 少 。 这 就 要 求 保 证 比较 和 设 〈 置 ) 值 这 两 个 动作 是 原子 性 操作 。 系 统 主 
要 利用 JNI (Java Native Interface，Java 本 地 接口 ) 来 保证 这 个 原子 操作 ， 它 利用 CPU 硬件 支 
持 来 完成 ， 使 用 便 件 提供 swap 和 test_and_set 指令 ， 单 CPU 下 同一 指令 的 多 个 指令 周期 不 可 
断 ，SMP 〈Symmetric Multi-Processing， 对 称 多 处 理 结 构 〉 中 通过 锁 总 线 支 持 这 两 个 指令 的 
原子 性 。 

2. 答案 : 本 题 中 , 最 简单 的 方法 是 对 数组 进行 顺序 壳 历 , 判断 遍历 到 的 数 是 否 满足 条 件 ， 
这 种 方法 的 效率 显然 是 最 低 的 。 下 面 介 绍 另 外 一 种 方法 ， 主 要 思路 如 下 : 如 果 a[i]>i， 则 接 下 
来 的 ali]-i-l 个 数 一 定 不 可 能 满足 ali]=i， 此 时 可 以 直接 遍历 下 标 为 寺 (arr[i-) 的 元 素 ， 从 而 减 
少 了 遍历 的 次 数 ， 实 现代 码 如 下 : 


import java.util.ArrayList;; 
public class Test 
{ 
public static ArrayList<Integer> find(int[| arr) 
{ 
ArrayList<Integer> result=new ArrayList<Integer>(); 
for(int 1=0,j=arr.length-1; 1<=j;) 
{ 
// 找 到 满足 条 件 的 数 ， 添 加 到 结果 中 ， 继 续 遍 历 下 一 个 数 
这 arr[i] ==)) 
result.add(i++); 
// 当 arr[i]>i 时 ， 则 接 下 来 的 a 中 -i-1 个 数 肯定 不 满足 a[i]=i 
else if(arr[i]>)) 
i=i+(arr[i]-)); 
/遍历 下 一 个 数 


else 


i 十; 
} 
return result; 
} 
public static void main(String[] args) 
{ 
int[] arr = { 1,1,1,3,5,7,8,9,10,11 }; 
ArrayList<Integer> result = find(arr); 
if(result.size()==0) 


{ 


System.out.printIn(" 不 存在 满足 条 件 的 数 "); 


else 
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for(int 1=0;i<result.size();i++) 
{ 
System.out.printn(" 满足 条 件 的 数 为 : al" + result.get(i) + "]==" + 
result.get(D)); 


1 

了 
程序 的 运行 结果 为 
满足 条 件 的 数 为 :a[1] 一 1 


品 


足 条 件 的 数 为 : a[3] 一 
3. 答案 : 本 题 考 察 的 是 对 Java 语言 文件 操作 的 理解 。 
本 题 的 主要 思路 如 下 : 首先 , 找到 指定 路 径 下 的 所 有 文件 , 然后 , 判断 这 些 文件 是 否 以 .txt 
或 .log 作为 后 级 ， 如 果 是 ， 则 为 要 找 的 文件 ， 此 时 输出 其 绝对 路 径 ， 否 则 ， 继 续 查 找 ， 直 到 
遍历 完 所 有 文件 为 止 。 
根据 以 上 分 析 即 可 编写 出 代码 ， 示 例 代码 如 下 : 


import java.io.File; 


import java.util.ArrayList; 
import java.util.List; 


public class Test 


{ 
public static void main(String[] args) 
{ 
List<String> fileTypes = new ArrayList<String>(); 
fileTypes.add("log"); 
fileTypes.add("txt"); 
String path = "ce:\"; 
List<String> files = getFiles(path, fileTypes); 
for (String f : files) 
{ 
System.out.println(f); 
} 
} 
public static List<String> getFiles(String path, List<String> fileTypes) 
{ 


List<String> result = new ArrayList<String>(); 
File fileDir = new File(path); 

1f (!fileDir.exists()) 

{ 


System.out.println(" 目 录 不 存在 "); 
return result; 

} 

// 获取 这 个 目录 下 的 所 有 文件 
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File[] fs = fileDir.listFiles(); 
for (File f: fs) 


{ 
/ 判断 是 否 是 文件 ， 而 不 是 目录 
让 (fisFileO) 
String fileName = f.getName(); 
String fileType = fileName.substring( 
fileName.lastIndexOf(".") + 1, fileName.length()); 
if (fileTypes.contains(fileType)) 
result.add(fileName); 
} 
} 
return result; 


} 


4. 答案 : 本 题 的 主要 思路 如 下 : 首先 对 数组 进行 排序 ， 然 后 从 后 往 前 遍历 数组 ， 对 于 每 
遍历 到 的 一 个 数组 元 素 afi， 判 断 从 0 到 a[i-1] 个 元 素 中 ,是 否 有 满足 afj]+a[kj=a[] Gk 二 i-1) 
的 值 。 在 判断 的 时 候 ， 可 以 采用 如 下 思路 : 从 前 往 后 遍历 子 数组 a[l0，…，i-1]， 对 于 遍历 到 
的 元 素 anj]， 判 断 在 子 数 组 afjt+1，…，i-1] 中 是 否 存在 af[i]-aj]， 如 果 存 在 ， 则 说 明 存 在 值 j 
和 k， 使 得 a[j]+a[k]=a[i]， 此 时 的 a 中 就 是 满足 条 件 的 最 大 值 。 

实现 代码 如 下 : 


rs 


import java.util.Arrays; 
public class Test 
| 
A 
* 用 二 分 法 判断 ar[low..….high] 中 是 否 存 在 data 
yy 
static boolean isExist(int[] arr, int low,int high,int data) 


{ 


while(low<=high) 
{ 
int mid=(low+high)/2; 
if(arr[mid] ==data) 
return true; 
else if(arr[mid]>data) 
high=mid-1; 
else 
low=mid+1; 
} 
return false; 
} 
static int findMaxValue(int[] arr) 


{ 
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if(arr==null || arr.length==0) 
return -1; 

Arrays.sort(arr); 

for(int i=arr.length-1; i>=2;i--) 


{ 
for(int j=0;j<i;j++) 
{ 
/判断 在 arlj..i-1] 是 否 存 在 arr[i]-am[j]， 如 果 存 在 说 明 存 在 一 个 k 使 得 
//arr[ljl+arr[k|=arr[i] 
if(isExist(arr,j,i-1,arr[i]-arr[j])) 
return arr[i]; 
} 
} 
return -1; 
} 
public static void main(String[] args) 
{ 
int[] a={1,2,3,3,4,3,2,8,9,6}; 
int result=findMaxValue(a); 
if(result==-1) 
System.out.println(" 不 存在 "); 
else 
System.out.println(" 满 足 条 件 最 大 的 值 为 : "+result); 
} 
} 
程序 的 运行 结果 为 


满足 条 件 最 大 的 值 为 :9 

5. 答案 : 本 题 考察 的 是 数据 库 的 知识 。 
(1) 分 析 
在 论坛 系统 中 ， 最 重要 的 对 象 就 是 用 户 与 帖子 。 显 然 ， 可 以 给 用 户 单独 设计 一 张 表 ， 由 
于 帖子 对 象 比较 特殊 ， 每 个 帖子 都 会 有 回复 帖 ， 而 回复 帖 也 会 有 回复 帖 ， 如 此 递归 。 由 于 论 
坛 中 会 有 大 量 的 帖子 ， 因 此 ， 对 帖子 表 的 设计 是 非常 重要 的 。 为 了 提高 查询 效率 ， 在 设计 的 
时 候 可 以 把 主题 帖 与 回复 帖 分 开 为 两 张 表 ， 对 于 回复 帖 的 回复 帖 ， 可 以 考虑 在 回复 帖 的 表 中 
增加 一 个 额外 的 字段 〈 回 复 帖 子 的 id)。 

(2) E-R 图 设计 

通过 以 上 分 析 可 知 , 这 个 简单 的 论坛 系统 主要 有 3 个 实体 : 用 户 ft_user、 主题 帖 t mainPost 
和 回复 帖 t replayPost。 它 们 之 间 有 如 下 关系 : 

1) 一 个 用 户 可 以 发 0 个 或 多 个 主题 帖 ， 因 此 ，t user 与 t mainPost 的 关系 为 一 对 多 的 关系 。 

2) 一 个 用 户 可 以 有 0 个 或 多 个 回复 帖 ， 因 此 ，t_user 与 t replayPost 的 关系 为 一 对 多 的 关系 。 

3) 一 个 主题 帖 可 以 有 0 个 或 多 个 回复 帖 ， 因 此 ，t_mainPost 与 t replayPost 的 关系 也 是 
一 对 多 的 关系 。 
通过 以 上 分 析 ， 数 据 库 设计 的 E-R 图 如 图 36 所 示 。 
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(3) E-R 图 转 关 系 模型 


图 36 “论坛 系统 的 E-R 图 


m title 
m content 
FK1 |u id 


r_title 
r_content 
r parent_ id 


当 把 图 36 的 E-R 图 转换 为 表 的 时 候 需 要 考虑 如 下 规则 : 


每 一 个 实体 可 以 转换 为 一 张 表 ， 实 体 的 属性 就 是 表 的 列 。 实 体 关系 的 转换 需要 遵循 下 面 


的 规则 : 


1) 一 个 1:1 的 关系 可 以 有 如 下 两 种 转换 方式 : 


QD 创建 单独 的 关系 表 ， 则 这 个 表 


PF 的 主要 内 容 为 1:1 关系 的 两 个 表 的 主键 。 
@ 两 个 实体 合并 为 一 张 表 ， 把 两 个 表 的 属性 合并 ， 创 建 一 张 表 。 


2) 一 个 1:n 的 关系 可 以 有 如 下 两 种 转换 方式 : 


FP 的 主要 内 容 为 1:n 关系 的 两 个 表 的 主键 。 


QD 创建 单独 的 关系 表 ， 则 这 个 表 
@ 通过 在 n 端的 表 中 引入 一 列 (1 
的 个 数 ， 从 而 提高 查询 效率 。 


端 表 的 主键 ) 作为 外 键 ， 一 般 采 用 这 种 方式 来 减少 表 


3) 一 个 min 关系 转换 为 一 个 关系 模式 。 只 能 创建 单独 的 关系 表 ， 关 系 表 中 的 主要 内 容 为 


两 个 表 的 主键 。 
上 面 设计 的 E-R 图 只 有 1:n 的 关系 ， 通 过 在 n 端 引入 1 端 实体 的 主键 ， 得 到 数据 库 表 结 
构 为 : 
1) t_user 表 〔 用 户 信 息 表 见 表 16) 
表 16 t_user 表 
列 名 类 型 键 措 述 
u id long 主键 户 ID 
u name varchar(20) 户 名 
u_email varchar(30) 户 邮箱 
u_addr varchar(100) 用 户 地 址 
u_ phone varchar(20) 用 户 号 码 
u_homepage varchar(50) 户主 页 url 
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2) t mainPost 表 (主题 帖 表 ， 见 表 17) 


表 17 t mainPost 表 
列 名 类 型 键 描述 
m_ id long 主键 帖子 ID 
m title varchar(50) 帖子 主题 
m content Varchar(1000) 帖子 内 容 
uid long 外 键 日 户 ID 
3) t replayPost 表 ( 回 复 帖 表 ， 见 表 18) 
表 18 t replayPost 表 
列 名 类 型 键 首 述 
rid long 主键 可 复 帖 子 ID 
r title varchar(50) 可 复 帖子 主题 
r_content Varchar(1000) 可 复 帖 子 内 容 
uid long 外 键 户 JD 
m id long 外 键 
r_paient id long 可 复 帖 的 父 帖 id 
(4) 结论 
1) 显然 ， 表 中 每 个 字段 不 可 再 分 ， 因 此 ， 满 足 1NF。 


2) 表 中 的 每 一 行 都 可 以 唯一 地 用 id 区 分 ， 且 不 存在 部 分 依赖 ， 因 此 ， 满 足 2NF。 
3) t replayPost 表 存 在 传递 依赖 (r id 一 r_paient id，r paient id~m id)， 因 此 ， 这 个 设 


计 不 满足 3NF。 


数据 库 的 范式 主要 目的 是 防止 数据 宛 余 、 更 新 异常 、 提 
但 是 高 的 范式 可 能 会 带 来 处 理 速度 缓慢 和 处 理 罗 辑 复杂 的 问题 。 因 
地 追求 高 范式 而 忽视 效率 。 对 于 本 是 
然 增加 了 宛 余 ， 但 是 能 明显 地 提高 效率 。 


越 少 。 


好 ， 在 实际 设计 的 时 候 ， 需 要 权衡 范式 与 效率 ， 而 不 能 盲目 
而 言 ，t replayPost 被 设计 为 不 满足 3NF， 虽 


入 异常 和 删除 异常 ， 范 式 越 高 ， 见 余 


此 ， 并 不 是 范式 越 高 越 


3 者 上 :六 某 知名 互联 网 公司 软件 工程 师 笔试 题 


单项 选择 题 
B 2. A 3. C 4. B 
B 10. B 11.C 
多 项 选择 题 
BD 2. AE 3. AC 
7. AC 8. BC 
. BCD 12. ACD 13. ABD 
a=3，b=4，c=3，Xx=10 


人 
怠 
过 
吕 
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日 


Java 程序 员 面试 笔试 真题 


2. Java.util 
3. public static void main(String[] args) 
4. 1 
5. 20 
四 、 编 程 题 
1. 答案 : 
class Test 
{ 
public static void main(String[] args) 
{ 
System.out.println("Hello world"); 
} 
} 
import java.applet.Applet; 
import java.awt.Graphics; 
class Test extends Applet 
《 
private String str; 
public void init() 
{ 
str="Hello world"; 
} 
public void paint(Graphics g) 
{ 
g.drawString(str, 10, 10); 
} 
} 
2 答案 


import java.io.BufferedOutputStream; 
import java.io.File; 

import java.io.FileNotFoundException; 
import java.io.FileOutputStream; 
import java.io.IOException; 


import java.util.Scanner; 


class Test 
和 
public static void main(String[] args) 
{ 
String name; 
String phone; 


Scanner scanner = new Scanner(System.in); 
BufferedOutputStream buff—null; 
FileOutputStream fos; 
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try { 
fos= new FileOutputStream(new File("phone.txt")); 
buff=new BufferedOutputStream(fos); 
while(true) 
{ 
System.out.printtn(" 请 输入 名 字 ， 或 输入 done 退出 "); 
name = scanner.nextLine(); 
if(name.trim().equalsIenoreCase("done")) 
break; 
System.out.printin(" 请 输入 手机 号 ， 或 输入 done 退出 "); 
phone = scanner.nextLine(); 
if(phone.trim().equalsIegnoreCase("done")) 
break; 
buff.write( (phone+","+name+"\n").getBytes()); 
} 
} catch (Exception e) 
{ 
e.printStackTrace(); 
} finally 
{ 
if(buff!=null) 
try { 
buff.close(); 
} catch (IOException e) { 
// TODO Auto-generated catch block 
e.printStackTrace(); 
} 
} 
} 
} 


0 划 了 A 某 知名 网 络 安全 公司 校园 招聘 技术 类 笔试 题 


一 、 选 择 题 
1. 答案 : D。 


分 析 : 本 题 考察 的 是 数学 知识 。 
根据 题目 中 的 描述 ， 可 以 画 一 个 表示 时 针 与 分 针 的 图 例 ， 如 图 37 所 示 。 


图 37 时 钟 图 例 
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正好 互 换 
图 是 一 个 


数 为 n，] 


分 针 转 过 的 角度 值 为 2xX3-0=6n-0。 


而 言 ，2 x 代表 一 圈 


假设 小 明 开 始 等 待 


试 笔试 真题 库 


女神 的 那 一 时 刻 时 针 与 分 针 的 夹 角 为 6 弧度 ， 那 么 ， 等 到 时 针 与 分 针 
Y 置 时 ， 时 针 走 过 了 6 弧度 ， 而 由 于 分 针 转 动 一 立 表示 的 时 间 为 一 个 小 时 ， 钟 表 一 
一， 表示 的 弧度 值 为 2x， 分 针 因 为 要 转 若 干 疾 才 能 到 达 时 针 的 位 置 ， 记 分 钟 所 转 图 
比 时 分 针 转 过 的 角度 则 为 2xn-0 弧度 。 


题目 强调 ,“ 时 间 一 分 一 秒 的 流逝 ， 两 个 多 小 时 过 去 了 ， 女 神 还 没有 出 现 ”， 通过 这 条 信 
县 可 知 ， 分 钟 转 了 2 一 3 圈 ， 接 近 3 轿 ， 此 时 可 知 ,，n 值 取 3， 所 以 ， 时 针 转 过 的 角度 值 为 9， 


对 于 时 针 而 言 ，2r 代表 一 圈 ， 即 12h， 那 么 弧度 6 表示 的 时 间 值 为 120/(2 mh， 对 于 分 针 


， 即 60min， 那 么 6 7-0 表示 的 是 60X(6 x-0)/(2 mmin。 由 于 时 钟 走 过 的 


时 间 值 与 分 钟 走 过 的 时 间 值 所 代表 的 时 间 量 是 一 个 量 ， 故 二 者 是 相等 的 ， 由 此 可 以 构建 如 下 
等 式 关系 : 


语 ; 


A 


[12 0/(2 rn)] X60 = 60X(6r-0) /(2 7) 


求解 上 述 等 式 可 知 ，9=6 x/13， 即 小 明 等 待 的 时 间 反 映 在 钟表 上 为 6 m13 弧度 值 ， 所 以 ， 
小 明 一 共 等 了 12X(6m13)/(2 mh， 即 36/13h， 合 166min。 所 以 ， 选 项 DD 正确 。 
所 以 ， 本 题 的 答案 为 D。 


2. 答案 : A。 


分 析 : 本 题 考察 的 是 逻辑 推理 知识 。 
这 是 一 道 富有 挑战 性 的 逻辑 推理 题 ， 也 常见 于 小 学 奥数 题 中 ， 主 要 考察 的 是 求职 者 的 好 
辑 思维 能 力 。 解 题 的 关键 在 于 通过 题 中 所 给 条 件 逐 级 推理 ， 同 时 使 用 推理 出 的 结果 作为 后 续 


E 理 的 条 件 ， 最 终 将 所 有 问题 解决 。 


根据 题目 中 的 各 类 条 件 ， 分 别 对 其 进行 编号 : 
“学 生 B 不 是 学 计算 机 的 ”中 

“学 计算 机 的 出 生 在 西安 ”@ 

“学 生 B 不 出 生 在 深圳 ”@ 

“学 化 学 的 不 出 生 在 武汉 ”外 

“学 生 A 不 是 学 化 学 的 ”加 

“学 计算 机 的 出 生 在 西安 ”@ 


注 


3. 答案 : C。 
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根据 以 上 6 个 条 件 可 以 进行 如 下 推理 ; 
根据 @@ 和 @ 可 以 推 
通过 (a〉 和 @@ 可 以 推断 ， 学生 B 出 生 在 武汉 。(b) 
根据 @@ 和 @ 可 以 推 
根据 〈c) 和 @ 可 以 推断 ， 学 生 A 学 的 是 计算 机 。(d) 
根据 (d》 和 @ 可 以 推断 ， 学 生 A 出 生 在 西安 。(e) 

天 下 的 就 是 学 生 C 出 生 在 深圳 ， 学 的 是 化 学 。 

所 以 最 后 的 结论 为 : 学 生 A 出 生 在 西安 ， 学 的 是 计算 机 ; 学 生 B 出 生 在 武汉 ， 学 的 是 英 
学 生 C 出 生 在 深圳 ， 学 的 是 化 学 。 可 以 将 最 后 的 结论 代入 题目 中 进行 验证 。 所 以 ， 选 项 
E 确 。 


所 以 ， 本 题 的 答案 为 A。 


断 : 学 生 B 出 生 在 武汉 或 深圳 。(a) 


新 : 学 生 B 学 的 是 英语 。(c) 


真题 详解 篇 


分 析 : 本 题 考查 的 是 排列 组 合 知 识 。 

题目 要 求 两 个 人 抽 到 的 小 球 颜色 相同 ， 而 此 题 有 两 个 关键 点 需要 注意 : 第 一 ， 每 个 人 取 
的 是 两 个 球 ， 而 不 是 一 个 球 ， 所 以 必须 要 求 两 个 球 的 颜色 是 一 模 一 样 的 才能 称 为 小 球 颜 色相 
同 ; 第 二 ， 每 种 球 的 数量 是 充足 的 ， 可 以 理解 为 球 的 数量 是 无 限 的 ， 不 存在 某 一 种 颜色 的 球 
被 全 部 取 完 而 后 面 的 人 无 法 取 到 的 情况 。 由 于 球 的 颜色 有 5 种 ,根据 排列 组 合 原理 ,5 种 情况 
下 取 的 球 的 颜色 情况 可 以 分 为 以 下 两 类 情况 : 

1) 取 的 两 个 球 的 颜色 相同 (每 个 人 取 的 球 的 颜色 是 不 相同 的 )， 有 5 种 情况 。 

2) 取 的 两 个 球 的 颜色 不 同 ，C(5,2)=10， 有 10 种 情况 。 

以 上 两 种 情况 合计 共有 15 种 情况 。 如 果 前 15 个 人 取 的 球 的 颜色 都 不 相同 ， 那 么 当 第 16 
个 人 取 球 时 ， 必 然 会 与 前 面 的 15 个 人 中 的 某 一 个 相同 。 所 以 ， 本 题 的 答案 为 16 个 。 

所 以 ， 本 题 的 答案 为 C。 

4. 答案 : C。 

分 析 : 本 题 考查 的 是 排列 组 合 知识 。 

题目 告知 ， 平 面 内 有 11 个 点 ， 如 果 这 些 点 中 任意 三 个 点 都 没有 共 线 ， 那 么 一 共有 C(11， 
2)=55 种 情况 ， 但 是 ， 根 据 题 意 ， 连 接 成 48 条 直线 ， 那 么 可 知 ， 这 11 个 点 中 必定 有 三 点 共 线 
以 及 三 点 以 上 共 线 的 ， £55-48=7 种 情况 。 

而 这 7 种 三 点 共 线 的 情况 又 可 以 划分 为 以 下 多 种 情况 : 

1) 假设 只 有 3 点 共 线 ， 令 3 点 共 线 的 直线 有 x 条， 那么 可 以 组 成 的 直线 在 55 的 基础 上 
应 该 减 去 这 种 情况 的 发 生 , 即 C(11,2)-xC(3,2)+1=48, 3x=8， 由 于 解 算出 来 的 x 的 值 不 是 整数 ， 
所 以 ， 此 种 情况 不 满足 条 件 。 

2) 假设 只 有 4 点 共 线 ， 令 4 点 共 线 的 直线 有 x 条， 那么 可 以 组 成 的 直线 在 55 的 基础 上 
应 该 减 去 这 种 情况 的 发 生 , 即 C(11,2)-xC(4,2)+1=48, 6x=8， 由 于 解 算出 来 的 x 的 值 不 是 整数 ， 
所 以 ， 此 种 情况 不 满足 条 件 。 

3) 假设 只 有 n (Cn>4) 点 共 线 ， 方 法 同上 ， 也 无 法 满足 条 件 。 

4) 若 有 3 点 共 线 及 4 点 共 线 两 种 情形 ， 令 3 点 共 线 的 直线 有 x 条 ，4 点 共 线 的 有 y 条 ， 
则 有 Ci 一 xC3 -yC++x+y=48， 即 2x+Sy=7， 所 以 x=1，y=1l。 这 11 个 点 中 ， 必 定 有 
一 组 3 点 共 线 ， 并 且 还 有 一 组 4 点 共 线 。 由 于 3 点 共 线 、4 点 共 线 都 不 能 组 成 三 角形 ， 所 以 这 
11 个 点 能 组 成 的 三 角形 的 个 数 为 C(11,3) -CG3,3)-C(4,3)=165-1-3=160。( 本 题 不 考虑 三 角形 
两 边 之 和 大 于 第 三 边 的 要 求 ) 

5) 若 有 3 点 共 线 、4 点 共 线 及 5 点 共 线 三 种 情形 ， 分 析 方 法 相同 。 可 知 方程 无 解 ， 超 过 
以 上 情况 的 多 点 共 线 的 情况 也 不 符合 题 意 。 

所 以 ， 本 题 的 答案 为 160。 

所 以 ， 本 题 的 答案 为 C。 

5. 答案 : B。 

分 析 : 本 题 考查 的 是 数列 知识 。 

本 题 是 一 个 数列 找 规 律 的 题目 ， 经 常 出 现在 小 学 奥数 或 者 高 中 生 升学 考试 中 ， 主 要 考查 
求职 者 的 逻辑 思维 能 力 。 

虽然 此 题 中 相 邻 项 的 商 并 不 是 一 个 常数 , 但 它们 是 按照 一 定 规律 排列 的 , 不 难 发 现 ， 
本 题 中 后 一 项 除 以 前 一 项 的 结果 构成 一 个 等 差 数 列 , 公差 1/2, 即 除 第 一 项 以 外 的 每 一 项 
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都 等 于 其 前 一 项 的 值 乘 以 (1+0.Sm0，a 的 值 为 从 0 开始 的 自然 数 。 有 具体 为 : 8X1=8， 
8X1.5=12，12X2=24，24X2.5=60， 根 据 这 一 规律 ，60 后 面 的 数 的 值 应 为 60X3=180。 
所 以 ， 选 项 B 正确 。 

所 以 ， 本 题 的 答案 为 B。 

6. 管 案 : D。 

分 析 : 本 题 考察 的 是 按 位 与 运算 符 & 的 知识 。 
解答 本 题 的 关键 在 于 理解 x=x& (x-1) 这 条 语句 的 作用 ,运算 符 & 是 一 个 二 进 制 的 运算 符 
号 ， 表 示 的 是 二 进 制 的 与 操作 ， 二 进 制 与 操作 具有 如 下 性 质 : 只 有 当 参 与 运算 的 两 位 同时 为 
“1” 时 ， 其 运算 结果 才 为 “1” 和 否则， 其 运算 结果 为 “0” 即 0&0=0, 0&1=0, 1&0=0, 1&1=1。 
例如 ， 十 进 制 数 10， 其 二 进 制 表示 为 1010， 它 与 十 进 制 数 9( 二 进 制 表示 为 1001) 执行 & 运 
算 时 ， 其 结果 为 1010 & 1001 = 1000。 

对 于 表达 式 x&(x-1) 而 言 ,其 结果 到 底 是 什么 呢 ?x 会 不 断 地 与 比 它 小 1 的 数 进行 与 运算 ， 
每 执行 一 次 x=x&(x-1) 操 作 ， 会 将 x 用 三 进 制 表示 时 最 右边 的 一 个 1 变 为 0， 因 为 x-1 会 将 该 
位 (x 用 二 进 制 表示 时 最 右边 的 一 个 1) 变 为 0。 这 段 代 码 的 目的 是 就 是 计算 x 的 二 进 制 表示 
中 1 的 个 数 。65530 对 应 的 二 进 制 表 示 为 1111 1111 1111 1010， 对 应 的 二 进 制 中 有 14 个 1。 所 
以 ， 选 项 D 正确。 

所 以 ， 本 题 的 答案 为 D。 

7. 答案 : B。 

分 析 : 本 题 考察 的 是 排序 算法 知识 。 

读者 要 想 解 答 出 本 题 ， 必 须 对 各 种 排序 算法 的 原理 有 着 较为 深刻 的 认识 。 以 下 将 分 别 对 
这 几 种 排序 算法 进行 介绍 与 分 析 。 

对 于 选项 A， 选 择 排序 是 一 种 简单 直观 的 排序 算法 ， 它 的 基本 原理 如 下 : 对 于 给 定 的 一 
组 记录 ， 经 过 第 一 轮 比较 后 得 到 最 小 的 记录 ， 然 后 将 该 记录 与 第 一 个 位 置 的 记录 进行 交换 ; 
接着 对 不 包括 第 一 个 记录 以 外 的 其 他 记录 进行 第 二 轮 比较 ， 得 到 最 小 的 记录 并 与 第 二 个 记录 
进行 位 置 交 换 ， 重 复 该 过 程 ， 直 到 进行 比较 的 记录 只 有 一 个 时 为 止 。 

对 于 选项 B， 人 快速 排序 是 一 种 非常 高 效 的 排序 算法 ， 它 采用 “分 而 治之 ”的 思想 ， 把 大 
的 拆 分 为 小 的 ， 小 的 再 拆 分 为 更 小 的 。 其 原理 为 : 对 于 一 组 给 定 的 记录 ， 通 过 一 趟 排序 后 ， 
将 原 序 列 分 为 两 部 分 ， 其 中 前 部 分 的 所 有 记录 均 比 后 部 分 的 所 有 记录 小 ， 然 后 再 依次 对 前 后 
两 部 分 的 记录 进行 快速 排序 ， 递 归 该 过 程 ， 直 到 序列 中 的 所 有 记录 均 有 序 为 止 。 

对 于 选项 C， 希 尔 排序 也 称 为 “缩小 增 量 排序 ” 它 的 基本 原理 如 下 : 首先 ， 将 待 排序 的 
元 素 分 成 多 个 子 序列 ， 使 得 每 个 子 序列 的 元 素 个 数 相对 较 少 ， 对 各 个 子 序列 分 别 进行 直接 插 
入 排序 ， 待 整个 待 排序 序列 “基本 有 序 后 ”再 对 所 有 元 素 进 行 一 次 直接 插入 排序 。 希 尔 排 序 
也 是 形成 部 分 有 序 的 序列 。 

对 于 选项 D， 归 并 排序 是 利用 递归 与 分 治 技术 将 数据 序列 划分 为 越 来 越 小 的 子 序 列 〈 子 
序列 指 的 是 在 原来 序列 中 找 出 一 部 分 组 成 的 序列 )， 再 对 子 序 列 排序 ， 最 后 再 用 递归 方法 将 排 
好 序 的 子 序列 合并 为 越 来 越 大 的 有 序 序列 。 归 并 排序 会 在 第 一 趟 结束 后 ， 形 成 若干 个 部 分 有 
序 的 子 序列 ， 并 且 长 度 递 增 ， 直 到 最 后 的 一 个 有 序 的 完整 序列 。 

本 题 中 ， 很 容易 发 现 ， 第 一 个 序列 前 4 个 数 都 小 于 等 于 2$， 而 后 $ 个 数 都 大 于 25$， 很 显 
然 满足 快速 排序 的 方法 ， 而 且 根 据 以 上 对 各 种 排序 算法 的 分 析 可 知 ， 选 项 B 正确 。 


ds 


一 局 


J 
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所 以 ， 本 题 的 答案 为 B。 


8. 答案 : B。 


分 析 : 本 题 考 察 的 是 二 又 树 知识 。 


通 二 又 树 还 是 其 他 二 又 树 )， 所 以 ， 其 高 度 存 在 不 确定 性 。 


也 不 小 于 最 小 值 。 


本 题 中 的 二 又 树 并 没有 说 明 到 底 是 一 棵 什么 类 型 的 二 又 树 〈 完 全 二 又 树 、 满 二 又 树 、 普 


定义 二 叉 树 中 的 结 点 总 数 为 n， 当 每 个 结 点 只 有 一 棵 子 树 的 时 候 ， 其 高 度 值 最 大 ， 为 
n。 当 该 二 叉 树 为 完全 二 叉 树 时 ， 其 高 度 值 最 小 ， 为 [log,n]+1 (其 中 1] 符号 表示 向 下 取 
整 )， 其 他 情况 的 二 又 树 的 高 度 都 是 介 于 这 两 个 值 之 间 ， 即 [flog; n]+1, n]， 不 大 于 最 大 值 


本 题 中 要 想 求 二 又 树 的 最 小 高 度 ， 那 么 此 时 该 二 叉 树 为 完全 二 叉 树 ， 其 对 应 的 高 度 为 


log2(360) 向 下 取 整 再 加 1， 即 等 于 9。 所 以 ， 选 项 B 正确 。 
所 以 ， 本 题 的 答案 为 B。 
9. 答案 : A。 
分 析 : 本题 考察 的 是 list 排序 知识 。 
首先 给 出 常见 的 排序 算法 的 性 能 ， 见 表 19。 


表 19 常见 排序 算法 的 性 能 


排序 方法 最 好 时 间 平均 时 间 最 坏 时 间 辅助 存储 稳定 性 备注 
简单 选择 排序 O(n’2) O(n’2) O(n’2) O01) 不 稳定 n 小 时 较 好 
直接 插入 排序 O(n) O(n’2) O(n’2) O(1) 稳定 大 部 分 已 有 序 时 较 好 
冒 泡 排序 O(n) Oa“^2) O(n’2) O(1) 稳定 n 小 时 较 好 
希 尔 排序 O(n) Onlog n) O(ns) 1<s<2 O() 不 稳定 s 是 所 选 分 组 
快速 排序 Omlog m) Onlog n) Oa^2) O(log n) 不 稳定 n 大 时 较 好 
堆 排序 O(nlog n) Omlog n) Omlog n) 0(1) 不 稳定 n 大 时 较 好 
归并 排序 Omnlog n) Onlog n) Oalog n) OO) 稳定 n 大 时 较 好 
对 于 选项 A， 需 要 注意 的 是 ， 在 C++ 语言 中 ，list 采用 的 是 双向 列表 来 存储 的 ， 因 此 ， 它 
比较 适合 用 快速 排序 (快速 排序 不 需要 随机 地 访问 元 素 )。 此 时 的 时 间 复 杂 度 为 Onlog n)。 所 
以 ， 选 项 A 正确 。 


对 于 选项 B， 冒 泡 排 序 也 是 对 数据 顺序 裔 历 ,， 不 需要 随机 访问 ， 


正确 。 


因此 ， 它 也 适合 对 list 


进行 排序 ， 但 由 于 算法 的 时 间 复 杂 度 为 O(n^2)， 没 有 快速 排序 效率 高 。 所 以 ， 选 项 B 不 


对 于 选项 C， 首 先 需 要 弄 清楚 二 分 插入 排序 的 基本 思想 。 二 分 插入 排序 的 基本 思想 如 下 : 
假设 列表 [0...n] 被 分 成 两 部 分 ， 其 中 一 部 分 [0...i] 为 有 序 序列 ， 另 一 部 分 [i+1...n] 为 无 序 序列 ， 


排序 的 过 程 为 从 无 序 序列 中 取 一 个 数 d, 利用 二 分 查找 算法 找到 d 在 有 序 序列 中 的 插入 位 置 
并 插入 。 不 断 重 复 上 述 步骤 ， 直 到 无 序 序列 中 的 元 素 全 部 插入 有 序 序列 ， 就 完成 了 排序 。 
它 不 适合 对 list 进行 排 


此 可 以 看 出 ,二 分 插入 排序 需要 对 列表 中 的 元 素 进 行 随机 访问 ， 因 此 ， 
序 。 所 以 ， 选 项 C 不 正确 


对 于 选项 D， 上 只 有 当 被 排序 的 元 素 满足 某 种 特定 的 条 件 的 时 候 ， 线 性 排序 算法 才能 有 较 


好 的 性 能 。 由 于 list 有 非常 好 的 通用 性 ， 对 任意 的 数据 类 型 都 能 排序 ， 因 此 ， 线 性 排序 算法 不 
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适用 对 list 进行 排序 。 所 以 ， 选 项 D 不 正确 。 


所 以 ， 本 题 的 答案 为 A。 


10. 答案 : A。 


分 析 : 本 题 考察 的 是 计算 机 网 络 与 通信 知识 。 


PING 命令 主要 是 为 了 检查 网 络 是 
出 报 文 协议 〉 应 答 报 文 3 


Message Protocol，Internet 控 和 


计算 机 或 本 地 计算 机 的 连接 。 对 于 每 个 发 送 报 文 ，PING 最 多 等 待 的 时 间 为 1s， 


不 
否 


通畅 ， 它 通过 向 计算 机 发 送 ICMP (Internet Control 
且 监 听 回 应 报 文 的 返回 ， 以 校 验 与 远程 


并 打印 发 送 和 


接收 报 文 的 数量 。 比 较 每 个 接收 报 文 和 发 送 报 文 ， 以 校 验 其 有 效 性 。 如 果 能 够 成 功 校 验 IP 地 
址 ， 但 不 能 成 功 校 验 计算 机 名 ， 则 说 明 名 称 分 析 存 在 问题 。 默 认 情 况 下 ， 发 送 4 个 回应 报 文 ， 
每 个 报 文 包含 64B 的 数据 (周期 性 的 大 写字 母 序列 )。 


为 了 更 好 地 说 明 PING 的 原理 与 应 
ping XXX.XXX.XXX.XXX (A 到 B) 实际 


1) A: 构建 ICMP 数据 包 data， 月 


j， 以 下 是 一 个 完整 的 PING 过 程 。 
上 执行 了 以 下 几 个 步骤 : 
日 ICMP 协议 把 data 连同 A 的 中 交 给 中层。 


2) IP 层 把 B 的 IP 作为 目的 地 址 ，A 的 IP 作为 源 地 址 ， 加 上 其 他 的 控制 信息 构建 全 数 


据 包 。 


3) 获取 B 的 MAC 地 址 ， 根 据 B 的 IP 地 


a) 如 果 属 于 同一 子 网 , 直接 如 


和子 网 掩 码 ， 检 测 是 否 属于 同一 子 网 。 
E 本 网 络 查 找 。 查找 本 机 的 ARP 的 缓存 , 找到 B 对 应 的 MAC 


地 址 ， 如 果 缓存 中 找 不 到 ， 则 表示 二 者 在 此 之 前 没有 进行 过 通信 ， 就 发 一 个 ARP 请求 广播 ， 


得 到 B 的 MAC 地 址 。 


b) 如 果 不 属 于 同一 个 子 网 ， 则 直接 交 给 路 | 


开关 


器 处 理 ， 就 是 获取 路 


器 的 MAC (步骤 同 


4) 交 给 数据 链 路 层 ， 构 建 数据 帧 ， 发 送 B。 

5) B 收 到 数据 帧 后 ,检测 数据 帧 的 目的 地 址 ， 若 不 是 发 给 本 机 的 数据 帧 ， 则 丢弃 ， 若 是 ， 
则 接收 , 然后 提取 出 人 p 数据 包 给 人 p 层 处 理 , 提取 数据 给 ICMP 协议 处 理 , 处 理 后 , 构建 ICMP 
应 答 包 ， 发 送 给 A， 过 程 同上 


通过 以 上 的 分 析 ， 选 项 A 正确 。 


所 以 ， 本 题 的 答案 为 A。 


11. 答案 : D。 


分 析 : 本 题 考 察 的 是 
正则 表达 式 (Regular Expression， 在 代码 
它 是 计算 机 科学 
一 系列 符合 某 个 句法 规则 的 字符 串 


示 法 、 常 规 表示 法 ， 


编译 原理 知识 。 


党 简写 为 regex、regexp 或 RE) 又 称 正规 表 


的 一 个 概念 。 正 则 表达 式 使 用 单个 


子 符 串 来 描述 、 匹 配 


表 20 列 出 了 所 有 的 元 字符 及 其 描述 。 
表 20 元 字符 及 其 描述 
\ 将 下 一 个 字符 标记 为 一 个 特殊 字符 , 或 一 个 原 义 字 符 , 或 一 个 向 后 引用 , 或 一 个 八进制 转 义 符 。 例如, “Nn” 
匹配 m。“m” 匹 配 换行 符 。 序 列 “\N” 匹 配 “\” 而 “\(” 则 匹配 “(” 
人 匹配 输入 字符 串 的 开始 位 置 。 如 果 设 置 了 RegExp 对 象 的 Multiline 属性 ，^ 也 匹配 “m ”或 “” 之 后 的 位 置 
$ 匹配 输入 字符 串 的 结束 位 置 。 如 果 设 置 了 RegExp 对 象 的 Multiline 属性 ，$ 也 匹配 “nn” 或 x” 之 前 的 位 置 
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( 续 ) 
元 字符 描述 
过 匹配 前 面 的 子 表达 式 零 次 或 多 次 (大 于 等 于 0 次 )。 例 如 ，zo* 能 匹配 “z”“zo” 以 及 “zoo”。* 等 价 于 {0,} 
是 匹配 前 面 的 子 表达 式 一 次 或 多 次 (大 于 等 于 1 次 )。 例 如 ,“zo+” 能 匹配 “zo” 以 及 “zoo” 但 不 能 匹配 “z”。 
+ 等 价 于 {1,} 
? 匹配 前 面 的 子 表达 式 零 次 或 一 次 。 例 如 ,“do(es)?” 可 以 匹配 “do” 或 “does” 中 的 “do”。? 等 价 于 {0,1} 


加 n 是 一 个 非 负 整数 。 匹 配 确 定 的 n 次。 例如 ,“of2}” 不 能 匹配 “Bob” 中 的 “o”， 但 是 能 匹配 “food” 中 的 
两 个 o 


fm,} n 是 一 个 非 负 整数 。 至 少 匹 配 n 次 。 例 如 ,“of2,} ”不 能 匹配 “Bob” 中 的 “o”， 但 能 匹配 “foooood” 中 
> 的 所 有 Os “of1,}” 等 价 于 “oF” “0{0,} » 则 等 价 于 OF 
Poa m 和 hm 均 为 非 负 整数 ， 其 中 n 万 m。 最 少 匹 配 n 次 且 最 多 匹配 m 次 。 例 如 ,，“o{1,3}” 将 匹配 “fooooood” 
中 的 前 三 个 o。“o{0,1}” 等 价 于 “0o? ”。 注 意 在 逗号 和 两 个 数 之 间 不 能 有 空格 
当 该 字符 紧 跟 在 任何 一 个 其 他 限制 符 〈*，+，?，fn}，fn}，{fnm}) 后 面 时 ， 匹 配 模式 是 非 贪 焚 的 。 非 贪 
禁 模 式 尽 可 能 少 地 匹配 所 搜索 的 字符 串 ， 而 默认 的 贪 禁 横 式 则 尽 可 能 多 地 匹配 所 搜索 的 字符 串 。 例 如 ， 对 于 
字符 串 “oo000”， “049” 将 匹配 单个 “0o”， 而 “o+” 将 匹配 所 有 “o” 
.点 匹配 除 “\mn” 之 外 的 任何 单个 字符 。 要 匹配 包括 “en” 在 内 的 任何 字符 ， 可 使 用 像 “[\s\S] ”的 模式 
oitiern) 匹配 pattern 并 获取 这 一 匹配 ,所 获取 的 匹配 可 以 从 产生 的 Matches 集合 得 到 ,在 VBScript 中 使 用 SubMatches 
集合 ， 在 JScript 中 则 使 用 $0.…9 属性 。 要 匹配 圆 括号 字符 ， 需 使 用 “\” 或 “Y)” 
匹配 pattern 但 不 获取 匹配 结果 ， 也 就 是 说 这 是 一 个 非 获取 匹配 ， 不 进行 存储 供 以 后 使 用 。 这 在 使 用 或 字符 
(?:pattern) “(D)” 来 组 合 一 个 模式 的 各 个 部 分 是 很 有 用 的 。 例 如 ,，“industr(?:ylies) ”就 是 一 个 比 “industrylindustries” 更 
简略 的 表达 式 
正 向 肯定 预 查 ， 在 任何 匹配 pattemn 的 字符 串 开始 处 匹配 查找 字符 串 。 这 是 一 个 非 获取 匹配 ， 也 就 是 说 ， 该 
patter 匹配 不 需要 获取 供 以 后 使 用 。 例如,“Windows(?=95|98INTI2000) ”能 匹配 “Windows2000” 中 的 “Windows”， 
但 不 能 匹配 “Windows3.1” 中 的 “Windows”。 预 查 不 消耗 字符 ， 也 就 是 说 ， 在 一 个 匹配 发 生 后 ， 在 最 后 一 次 
匹配 之 后 立即 开始 下 一 次 匹配 的 搜索 ， 而 不 是 从 包含 预 查 的 字符 之 后 开始 
正 向 否定 预 查 ， 在 任何 不 匹配 pattern 的 字符 串 开 始 处 匹配 查找 字符 串 。 这 是 一 个 非 获 取 匹 配 ， 也 就 是 说 ， 
(?!pattern) 该 匹配 不 需要 获取 供 以 后 使 用 。 例 如 ,“Windows(?!195|98|INTI2000) ”能 匹配 “Windows3.1” 中 的 “Windows”， 
但 不 能 匹配 “Windows2000” 中 的 “Windows” 
Ce 有 反 向 肯定 预 查 ， 与 正 向 肯定 预 查 类 似 ， 只 是 方向 相反 。 例 如 ,，“(?<=95|98INTI2000)Windows ”能 匹配 
sb “2000Windows” 中 的 “Windows”， 但 不 能 匹配 “3.1Windows” 中 的 “Windows” 
(0<tpattern) 反问 否定 预 查 ， 与 正 向 否定 预 查 类 似 ， 只 是 方向 相反 。 例 如 ,，“(?<!95|98INTI2000)Windows ”能 匹配 
“*P “3.1Windows” 中 的 “Windows”， 但 不 能 匹配 “2000Windows” 中 的 “Windows” 
xly 匹配 x 或 y。 例 如 ,，“zlfood” 能 匹配 “z” 或 “food”。 “(zlbood” 则 匹配 “zood” 或 “food” 
[xyz] 字符 集合 。 匹 配 所 包含 的 任意 一 个 字符 。 例 如 ,“[abc] ”可 以 匹配 “plain” 中 的 “a” 
[^xyz] 负 值 字符 集合 。 匹 配 未 包含 的 任意 字符 。 例 如 ,“[^abc] ”可 以 匹配 “plain” 中 的 “plin” 
字符 范围 。 匹 配 指定 范围 内 的 任意 字符 。 例 如 ,“[a-z] ”可 以 匹配 “a” 一 “z” 范 围 内 的 任意 小 写字 母 字 
符 。 
[a 注意 : 只 有 连 字符 在 字符 组 内 部 时 ， 并 且 出 现在 两 个 字符 之 间 时 ， 才 能 表示 字符 的 范围 ， 如 果 出 现在 字符 
组 的 开头 ， 则 只 能 表示 连 字 符 本 身 
[va 本 负 值 字符 范围 。 匹 配 任何 不 在 指定 范围 内 的 任意 字符 。 例 如 ,“[Aa-z ”可 以 匹配 任何 不 在 “a” 一 “z” 范 
围 内 的 任意 字符 
vb 匹配 一 个 单词 边界 ， 也 就 是 指 单词 和 空格 间 的 位 置 。 例 如 ,“erb” 可 以 匹配 “never” 中 的 “er”， 但 不 能 匹 
配 “verb” 中 的 i 
\B 无 配 非 单词 边界 。 例 如 ,，“enB” 能 匹配 “verb” 中 的 “er”， 但 不 能 匹配 “never” 中 的 “er” 
Ne 匹配 由 x 指明 的 控制 字符 。 例 如 ，\cM 匹配 一 个 Control-M 或 回 车 符 。x 的 值 必 须 为 A~Z 或 a~z 之 一 。 否 
则 ， 将 c 视 为 一 个 原 义 的 “c” 字 符 
\d 匹配 一 个 数字 字符 。 等 价 于 [0-9 
\D 匹配 一 个 非 数 字 字 符 。 等 价 于 [^0-9] 
¥f 匹配 一 个 换 页 符 。 等 价 于 x0c 和 \cL 
n 匹配 一 个 换行 符 。 等 价 于 \x0a 和 \cJ 
匹配 一 个 回 车 符 。 等 价 于 \x0d 和 \cM 
\s 匹配 任何 空白 字符 ， 包 括 空格 、 制 表 符 和 换 页 符 等 。 等 价 于 [ \fn\r\t\v] 
\S 匹配 任何 非 空白 字符 。 等 价 于 [^ fmvetvv] 
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vt 匹配 一 个 制 表 符 。 等 价 于 \x09 和 \cI 
Vv 匹配 一 个 垂直 制 表 符 。 等 价 于 \x0b 和 \cK 
Ww 下 本 包括 下 划 线 的 任何 单词 字符 。 类 似 但 不 等 价 于 “[A-Za-z0-9 ]”， 这 里 的 “单词 ”字符 使 用 Unicode 字符 集 
\W 匹配 任何 非 单词 字符 。 等 价 于 “[^AA-Za-z0-9 ]” 
a 匹配 n， 其 中 mn 为 十 六 进 制 转 义 值 。 十 六 进 制 转 义 值 必须 为 确定 的 两 个 数字 长 。 例 如 ,“\x41” 匹 配 “A” 
“x041” 则 等 价 于 “\x04&1”。 正则 表达 式 中 可 以 使 用 ASCII 编码 
\num 匹配 num， 其 中 num 是 一 个 正 整数 。 对 所 获取 的 匹配 的 引用 。 例 如 ,“( 和 1” 匹配 两 个 连续 的 相同 字符 
a 标识 一 个 八进制 转 义 值 或 一 个 向 后 引用 。 如 果 \n 之 前 至 少 有 n 个 获取 的 子 表 达 式 ， 则 n 为 向 后 引用 。 和 否则 ， 
如 果 n 为 八进制 数字 (0~~7)， 则 n 为 一 个 八进制 转 义 值 
标识 一 个 八进制 转 义 值 或 一 个 向 后 引用 。 如 果 \nm 之 前 至 少 有 nm 个 获得 子 表达 式 ， 则 nm 为 向 后 引用 。 如 
\nm 果 \nm 之 前 至 少 有 nn 个 获取 ， 则 1n 为 一 个 后 跟 文字 m 的 向 后 引用 。 如 果 前 面 的 条 件 都 不 满足 ， 若 n 和 m 均 为 
八进制 数字 (0 一 7)， 则 \mm 将 匹配 八进制 转 义 值 nm 
ml 如 果 n 为 八进制 数字 〈0 一 7)， 且 m 和 1 均 为 八进制 数字 〈0 一 7)， 则 匹配 八进制 转 义 值 nml 
\un 匹配 n， 其 中 是 一 个 用 4 个 十 六 进 制 数字 表示 的 Unicode 字符 。 例 如 ，\u00A9 匹配 版 权 符 号 〈&copy;) 
< 匹配 词 word) 的 开始 CA<) 和 结束 〈>)。 例 如 ， 正 则 表达 式 \<thev> 能 够 匹配 字符 串 “for the wise” 中 的 
“the”， 但 是 不 能 匹配 字符 串 “otherwise” 中 的 “the”。 注 意 :; 这 个 元 字符 不 是 所 有 的 软件 都 支持 的 
V 将 和 之 闻 的 表达 式 定义 为 “组 ”Cgroup)， 并 且 将 匹配 这 个 表达 式 的 字符 保存 到 一 个 临时 区 域 (一 个 
正则 表达 式 中 最 多 可 以 保存 9 个 )， 它 们 可 以 用 \1~\9 的 符号 来 引 
将 两 个 匹配 条 件 进行 逻辑 “或 ”"(Or) 运算 。 例如, 正则 表达 式 Chimlher) 匹配 “it belongs to him” 和 “it belongs 
to her”， 但 是 不 能 匹配 “it belongs to them.”。 注 意 : 这 个 元 字符 不 是 所 有 的 软件 都 支持 的 
于 匹配 1 个 或 多 个 正好 在 它 之 前 的 那个 字符 。 例 如 正则 表达 式 9+ 匹 配 9、99、999 等 。 注 意 : 这 个 元 字符 不 
是 所 有 的 软件 都 支持 的 
? 匹配 0 个 或 1 个 正好 在 它 之 前 的 那个 字符 。 注 意 : 这 个 元 字符 不 是 所 有 的 软件 都 支持 的 
匹配 指定 数目 的 字符 ， 这 些 字 符 是 在 它 之 前 的 表达 式 定义 的 。 例 如 ， 正 则 表达 式 A[0-9]{3} 能 够 匹配 字符 
{i “A” 后 面 跟着 正好 3 个 数字 字符 的 串 , 例如 A123、A348 等 , 但 是 不 匹配 A1234。 而 正则 表达 式 [0-9]{4,6} 匹 
配 连续 的 任意 4 个 、5 个 或 者 6 个 数字 
根据 以 上 描述 可 知 ， 本 题 中 的 正则 表达 式 表 示 的 是 无 符号 数 集合 。 
对 于 选项 A 和 选项 B, 在 正则 表达 式 number -> digits optionalFraction optionlExponent 中 ， 


过 与 
选 


的 。 


匹配 digits 就 可 以 了 ，optionalFraction 和 optionlExponent 都 匹配 s 即 可 。 所 以 ， 选 项 A 与 
项 B 都 是 下 而 
对 于 选项 C， 在 正则 表达 式 number -> digits optionalFraction optionlExponent ! 


只 匹配 


-过 


digits 和 optionalFraction，digits 匹配 为 2，optionalFraction ->.digitsls 匹配 .digits， 这 个 digits 


匹配 为 0。 所 以 ， 选 项 C 正确 
对 于 选项 D， 


选项 D 不 正确 


本 进行 分 析 并 确定 
组 件 出 现 ， 其 作 月 
树 、 抽 象 语法 树 等 


A 


V 


Or Ar 


于 付 


o 


o 


所 以 ， 本 题 的 答案 为 D。 
12. 答案 : A。 
分 析 : 本 题 考察 的 是 编译 原理 知识 。 
语法 分 析 是 根据 某 种 给 定 的 形式 文法 对 由 单词 序列 (例如 英语 单词 序列 ) 构成 的 输入 文 


口 


其 语法 结构 的 一 种 过 各 


Co 


昌 是 进行 语法 检查 ， 并 构建 
层次 化 的 数据 结构 )。 语 流 


对 流 中 分 离 上 
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一 个 个 的 “ 


k 词 ” 


语 


由 输 


分 证 


法 分 析 器 (Parser) 


并 将 单词 流 作为 其 输入 。 实 际 


E 后 面 必 须要 跟 一 个 digits 才 可 以 ， 即 E 不 可 能 为 结束 


证 


1 


性 万 语 


子 付 。 


所 以 ， 


常 作为 编译 器 或 解释 器 的 
入 的 单词 组 成 的 数据 结构 (一 般 是 语法 分 析 
器 通常 使 用 一 个 独立 的 词法 分 析 器 从 输入 字 
发 中 ， 语 法 分 析 器 可 以 手工 


汶 


写 ， 也 可 以 使 用 工具 〈 半 ) 自动 生成 。 

通常 ， 语 法 分 析 器 主要 可 以 通过 两 种 方式 完成 : 

1) 自 顶 向 下 分 析 : 根据 形式 语法 规则 ， 在 语法 分 析 树 的 自 顶 向 下 展开 中 搜索 输入 符号 
可 能 的 最 左 推 导 。 单 词 按 从 左 到 右 的 顺序 依次 使 用 。 

2) 自 底 向 上 分 析 : 语法 分 析 器 从 现 有 的 输入 符号 串 开始 ， 尝 试 将 其 根据 给 定 的 形式 语法 
规则 进行 改写 ， 最 终 改 写 为 语法 的 起 始 符号 。 

通过 以 上 的 分 析 可 知 ， 语 法 分 析 器 可 以 用 于 识别 语法 错误 。 所 以 ， 选 项 A 正确 。 

语义 分 析 是 编译 过 程 的 一 个 逻辑 阶段 ， 语 义 分 析 的 任务 是 对 结构 上 正确 的 源 程序 进行 上 
下 文 有 关 性 质 的 审查 ， 进 行 类 型 审查 ， 语 义 分 析 是 审查 源 程 序 有 无 语义 错误 ， 为 代码 生成 阶 
段 收集 类 型 信息 。 所 以 ， 对 于 语义 相关 的 处 理 都 是 由 语义 分 析 阶 段 实 现 的 ， 而 非 语法 分 析 阶 
段 ， 故 而 选项 了 B、 选 项 C 及 选项 DD 都 是 错误 的 。 

所 以 ， 本 题 的 答案 为 A。 

13. 答案 : D。 

分 析 : 本 题 考 察 的 是 计算 机 网 络 与 通信 知识 。 

IPv6 (Internet Protocol Version 6) 是 IETF (Internet Engineering Task Force， 互 联网 工程 
任务 组 ) 设计 的 用 于 替代 现行 版 本 卫 协议 (IPv4) 的 下 一 代 卫 协议 。 它 由 128 位 二 进 制 数码 
表示 ， 以 16 位 为 一 组 ， 每 组 以 冒号 “:” 隔 开 ， 可 以 分 为 8 组 ， 每 组 以 4 位 十 六 进 制 方式 表 
示 ， 一 个 十 六 进 制 相当 于 四 个 二 进 制 ， 即 十 六 位 二 进 制 数 表示 。 例 如 ，2001:0db8:85a3: 
08d3:1319:8a2e:0370:7344 是 一 个 合法 的 IPv6 地 址 。 所 以 ， 选 项 D 正确 。 

所 以 ， 本 题 的 答案 为 D。 

14. 答案 : C。 

分 析 : 本 题 考 察 的 是 Socket 通信 中 流 的 知识 。 

read 方法 用 来 从 输入 流 中 读 取 数据 的 下 一 个 字 节 ， 返 回 0 一 255 范围 内 的 int 字 节 值 。 如 
果 因 为 已 经 到 达 流 末尾 而 没有 可 用 的 字 节 ， 那 么 返回 值 为 -1。 在 输入 数据 可 用 、 检 测 到 流 末 
尾 或 者 抛 出 异常 前 ， 此 方法 一 直 阻 塞 。 

所 以 ， 本 题 的 答案 为 C。 

15. 答案 : D。 

分 析 : 本 题 考 察 的 是 操作 系统 中 内 核对 象 的 知识 。 

一 个 内 核对 象 就 是 在 系统 堆 中 占据 一 块 空 间 的 结构 体 。 不 同 种 类 的 内 核对 象 用 来 管理 操 
作 系 统 中 不 同 的 资源 ， 例 如 进程 、 线 程 和 文件 等 。 所 有 内 核对 象 都 会 保存 该 对 象 的 引用 计数 ， 
进程 对 象 会 保存 进程 ID， 文 件 对 象 会 保存 当前 字 节 偏 移 量 、 共 享 模式 及 打开 模式 等 。 操 作 系 
统 中 所 有 内 核对 象 都 是 保存 在 一 块 内 存 空 间 中 的 ,系统 上 所 有 的 进程 都 共享 这 一 块 内 存 空间 。 

每 个 进程 中 访问 临界 资源 的 那 段 程序 称 为 临界 区 临界 资源 是 一 次 仅 允 许 一 个 进程 使 用 
的 共享 资源 )。 每 次 只 允许 一 个 进程 进入 临界 区 ， 进 入 后 不 允许 其 他 进程 进入 。 

互 斥 对 象 是 一 种 最 简单 的 内 核对 象 ， 使 用 它 可 以 方便 地 实现 对 某 一 资源 的 互 斥 访问 。 而 
临界 区 并 不 是 内 核对 象 ， 而 是 系统 提供 的 一 种 数据 结构 ， 程 序 中 可 以 声明 一 个 该 类 型 变量 ， 
之 后 用 它 来 实现 对 资源 的 互 斥 访问 。 当 希望 访问 某 一 临界 资源 时 ， 先 将 该 临界 区 加 锁 《〈 如 果 
临界 区 不 空 尊 ， 则 等 待 )， 使 用 完 该 资源 后 ， 将 临界 区 释放 。 

所 以 ， 本 题 的 答案 为 D。 
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16. 答案 : B。 
分 析 : 本 题 考 察 的 是 线程 的 知识 。 
进程 是 资源 分 配 的 基本 单位 ;线程 是 系统 调度 的 基本 单位 。 
开发 人 员 平 时 编写 的 程序 都 是 作为 进程 运行 的 ， 进 程 可 以 看 作 是 包括 一 系列 线程 和 资源 
的 统称 ， 一 个 进程 至 少 包 括 一 个 线程 (主线 程 ， 进 入 main 函数 时 产生 的 )， 在 进程 中 可 以 创 
建 其 他 线程 ， 也 可 以 不 创建 。 

线程 共享 的 环境 包括 进程 代码 段 、 进 程 的 公有 数据 (利用 这 些 共享 的 数据 ， 线 程 很 容易 
实现 相互 之 间 的 通信 )、 堆 中 的 数据 、 进 程 打开 的 文件 描述 符 、 信 号 的 处 理 器 、 进 程 的 当前 目 
录 和 进程 用 户 ID 与 进程 组 ID 。 

线程 拥有 这 许多 共性 的 同时 ， 还 拥有 自己 的 个 性 。 有 了 这 些 个 性 ,线程 才 能 实现 并 发 性 。 
这 些 个 性 包括 : 

(1) 线程 ID 

每 个 线程 都 有 自己 的 线程 DD， 这 个 ID 在 本 进程 中 是 唯一 的 。 进 程 用 此 来 标识 线程 。 

(2) 寄存 器 组 的 值 
于 线程 间 是 并 发 运行 的 ， 每 个 线程 都 有 自己 不 同 的 运行 环境 ， 当 从 一 个 线程 切换 到 另 
一 个 线程 上 时 ， 必 须 将 原 有 的 线程 的 寄存 器 集合 的 状态 保存 ， 以 便 将 来 该 线程 重启 时 能 得 以 
恢复 。 

(3) 线程 的 栈 

酚 是 保证 线程 独立 运行 所 必需 的 。 线 程 函数 可 以 调用 函数 ， 而 被 调用 函数 中 又 是 可 以 层 
层 嵌 套 的 ， 所 以 ， 线 程 必须 拥有 自己 的 函数 栈 ， 使 得 函数 调用 可 以 正常 执行 ， 不 受 其 他 线程 
的 影响 。 

(4) 错误 返回 码 
由 于 同一 个 进程 中 有 很 多 个 线程 在 同时 运行 ， 可 能 某 个 线程 进行 系统 调用 后 设置 了 errno 
值 ， 而 在 该 线程 还 没有 处 理 这 个 错误 时 ， 另 外 一 个 线程 就 在 此 时 被 调度 器 调度 运行 ， 这 样 错 
误 值 就 有 可 能 被 修改 。 

所 以 ， 不 同 的 线程 应 该 拥有 自己 的 错误 返回 码 变量 。 

(5) 线程 的 信号 屏蔽 人 码 
由 于 每 个 线程 所 感 兴趣 的 信号 不 同 ， 所 以 ， 线 程 的 信号 屏蔽 码 应 该 由 线程 自己 管理 。 但 
所 有 的 线程 都 共享 同样 的 信号 处 理 器 。 

(6) 线程 的 优先 级 
于 线程 需要 像 进程 那样 能 够 被 调度 ， 那 么 就 必须 要 有 可 供 调度 使 用 的 参数 ， 这 个 参数 
是 线程 的 优先 级 。 

通过 以 上 分 析 可 知 ， 选 项 A、 选 项 C 与 选项 DD 错误 。 对 于 数据 区 而 言 ， 线 程 通常 都 可 以 
通过 公共 的 数据 区 进行 通信 ， 因 此 ， 选 项 B 正确 。 

所 以 ， 本 题 的 答案 为 了 B。 

17. 答案 ， A。 

分 析 : 本 题 考察 的 是 操作 系统 知识 。 

本 题 中 ， 首 先 需要 弄 清 楚 一 个 概念 ， 就 是 什么 叫 作 页 面 置 换 。 地 址 映射 过 程 中 ， 如 果 在 
页 面 中 发 现 所 要 访问 的 页 面 不 在 内 存 中 ， 则 产生 缺 页 中 断 。 当 发 生 缺 页 中 断 时 ， 操 作 系统 必 
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须 在 内 存 中 选择 一 个 页 面 将 其 移出 内 存 ， 以 便 为 即将 调 入 的 页 面 让 出 空间 。 而 用 来 选择 淘汰 
哪 一 页 的 规则 叫 作 页 面 置 换算 法 ， 也 称 为 页 面 淘汰 算法 。 

先进 先 出 页 面 淘汰 算法 简称 FIFO (First In First Out) 算法 ， 该 算法 实现 时 ， 最 早 进入 内 
存 的 页 面 ， 即 在 内 存 中 驻 留 时 间 最 久 的 页 面 ， 会 最 先 离开 内 存 。 该 算法 实现 简单 ， 只 需 把 调 
入 内 存 的 页 面 根 据 先后 次 序 链接 成 队列 ， 设 置 一 个 指针 总 指向 最 早 的 页 面 。 

本 题 中 ， 页 面 置换 过 程 如 下 所 示 。 

1) 访问 1， 缺 页 ， 调 入 1， 内 存 中 为 1。 

2) 访问 2， 缺 页 ， 调 入 2， 内存 中 为 1、2。 

3) 访问 3， 缺 页 ， 调 入 3， 内 存 中 为 1、2、3。 

4) 访问 4， 缺 页 ， 调 入 4， 淘汰 1， 内 存 中 为 2、 

5) 访问 1， 缺 页 ， 调 入 1， 淘 汰 2， 内存 中 为 3、 

6) 访问 2， 缺 页 ， 调 入 2， 淘汰 3， 内 存 中 为 4、 

7) 访问 5， 缺 页 ， 调 入 $， 淘 汰 4， 内 存 中 为 1、 

8) 访问 1， 不 缺 页 ， 内 存 中 为 1、2、5。 

9) 访问 2， 不 缺 页 ， 内 存 中 为 1、2、5。 

10) 访问 3， 缺 页 ， 调 入 3， 淘 汰 1， 内 存 中 为 2、5、3。 

11) 访问 4， 缺 页 ， 调 入 4， 淘 汰 2， 内 存 中 为 S$、3、4。 

12) 访问 5， 不 缺 页 ， 内 存 中 为 5、3、4。 

13) 访问 6， 缺 页 ， 调 入 6， 淘汰 3， 内 存 中 为 3、4、6。 

所 以 ， 一 共产 生 了 10 次 缺 页 。 因 此 ， 选 项 A 正确 。 

所 以 ， 本 题 的 答案 为 A。 

18. 答案 : A。 

分 析 : 本 题 考察 的 是 计算 机 组 成 原理 知识 。 

中 断 是 指 计算 机 在 执行 期 间 ， 系 统 内 发 生 任何 非 寻 常 的 或 非 预 期 的 急需 处 理事 件 ， 使 得 
CPU 和 暂时 中 断 当前 正在 执行 的 程序 而 转 去 执行 相应 的 事件 处 理 程序 ， 待 处 理 完 毕 后 又 返回 原 
来 被 中 断 处 继续 执行 或 调度 新 的 进程 执行 的 过 程 。 引 起 中 断 发 生 的 事件 被 称 为 中 断 源 。 中 断 
源 向 CPU 发 出 的 请 求 中 断 处 理 信 号称 为 中 断 请 求 ， 而 CPU 收 到 中 断 请 求 后 转 到 相应 的 事件 
处 理 程序 称 为 中 断 响 应 。 中 断 是 异步 过 程 调用 ， 简 而 言 之 ， 就 是 打 断 当前 CPU 正在 执行 的 任 
务 转 而 去 执行 另 一 个 任务 。 

中 断 必 须 满 足以 下 4 个 基本 条 件 : 

1) 一 条 指令 执行 结束 。 

2) CPU 处 于 开 中 断 状 态 。 

3) 当前 没有 发 生 复位 、 保 持 和 非 屏 蔽 中 断 请 求 。 

4) 如 果 当 前 执行 的 指令 是 开 中 断 指 令 和 中 断 返 回 指令 ， 则 它们 执行 完 后 再 执行 一 条 指 
令 ，CPU 才能 响应 INTR 请 求 。 

本 题 中 ， 键 盘 每 按键 一 次 ， 或 鼠标 单 击 一 次 ， 都 会 产生 一 个 中 断 ， 称 为 按键 中 断 ， 执 行 
中 断 响应 程序 ， 操 作 系 统 将 按键 消息 加 入 消息 队列 。 所 以 ， 选 项 A 正确 ， 而 选项 B、 选 项 C 
及 选项 DD 都 不 正确 。 

所 以 ， 本 题 的 答案 为 A。 


iD 一 上 上 ww 
- pA - pA 
nO 一 上 
o [oe] 0o [oe] 


~ 
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19. 答案 : B。 
分 析 : 本 题 考 察 的 是 操作 系统 基础 知识 。 


在 计算 机 中 ， 
B 使 用 设备 的 时 候 去 使 月 


执行 。 


单独 来 看 , 程 


于 程 


序 是 顺序 执行 
日 CPU， 也 就 是 说 ， 只 有 等 到 程 


而 不 是 并 发 执行 ， 所 以 ， 本 题 中 ， 程 序 A 不 能 在 程序 
序 A 执行 完毕 了 ， 程 序 B 才 会 被 开始 


序 A 


和 独 执行 需要 的 总 时 间 为 (10+5+5+10+10)s=40s, 程序 B 单独 执行 需要 


的 总 时 间 为 (10+10+5+5+10)s=40s， 二 者 单独 运行 需要 的 总 时 间 为 80s。 


对 于 程序 A 而 言 ，CPU 时 间 为 (10+5+10)s=25s， 对 于 
所 以 ，CPU 时 间 综 合 为 (25+15)s=40s， 所 以 ，CPU 的 利 


正确 。 


所 以 ， 本 题 的 答案 为 了 B。 
20. 答案 ， A。 
21. 答案 : A。 
分 析 : 本 题 考察 的 是 操作 系统 基础 知识 。 


对 于 选项 A， 可 抢占 式 会 引起 系统 的 开销 更 大 。 可 抢占 式 (Preemptive) 调度 是 严格 保证 
对 刻 ， 让 具有 最 高 优先 级 的 进 
程 保留 现场 ， 为 获取 到 处 理 机 的 进程 恢复 现场 等 时 间 (和 空间 )， 因 


占 式 (Nonpreemptive) 是 让 进程 运行 直到 结束 或 阻塞 的 调度 方式 (容易 实现 ， 


任何 
时 需要 为 退 昌 


销 比 较 大 。 


的 进 


F 抢 


适合 专用 系统 ， 不 适合 通 


对 于 选项 B， 


人 


用 系统 )。 所 以 ， 选 项 A 不 正确 。 
内 核 中 ， 对 应 于 每 个 进 
有 文件 。 文 件 描 述 表 中 每 一 项 都 是 一 个 指针 ， 指 向 一 个 用 了 


j 象 ，file 对 象 中 描述 了 文件 的 打开 模式 、 读 写 位 


口 


闻 B 而 言 ，CPU 时 间 为 (10+5)s=15s， 
了 率 为 40s/80s=50%。 所 以 ， 选 项 B 


程 占有 处 因此 ， 增 加 了 处 理 机 调度 的 时 间 ， 同 


此 ， 开 


里 机 运行 ， 


程 都 有 一 个 文件 


描述 符 表 ， 表 示 这 个 进程 打开 的 所 
描述 打开 的 文件 的 数据 块 一 一 file 
要 信息 ， 当 进程 打开 一 个 文件 时 ， 内 


5 和合 


于 


核 就 会 创建 一 个 新 的 file 对 象 。 需 要 注意 的 是 ，file 对 和 象 不 是 专属 于 某 个 进程 的 ， 不 同 进程 的 


文件 描述 符 表 


正确 。 


对 于 选项 C，ROM 和 RAM 指 的 都 是 半导体 存储 器 ，ROM 在 系统 停止 供 ! 


FP 的 指针 可 以 指向 相同 的 file 对 象 ， 从 
计数 ， 记 录 了 引用 这 个 对 象 的 文件 描述 符 个 数 ， 
象 ， 因 此 ， 某 个 进程 关闭 文件 ， 不 


i 共享 这 个 打开 的 文件 。file 对 象 有 引用 
只 有 当 引 用 计数 为 0 时， 内核 才 销 毁 file 对 
同一 个 file 对 象 的 进程 。 所 以 ， 选 项 B 


司 / 
会 影 


响 与 之 共享 


BE 的 时 候 仍 然 


可 以 保持 数据 ， 而 RAM 通常 都 是 在 掉 电 之 后 就 丢失 数据 ， 典 型 的 RAM 就 是 计算 机 的 内 存 。 


做 盘 


存储 设备 ， 


在 等 待 其 中 另 一 个 进程 所 占 
选项 D 正确 。 


锁 ”。 所 以 ， 


是 一 种 类 似 磁带 的 计算 机 的 外 部 存储 器 , 它 将 
SSD (Solid State Drives， 固 态 便 
由 控制 单元 和 存储 单元 (FLASH 
中 ， 访 问 速度 最 快 的 是 RAM， 访 问 速度 最 慢 的 是 磁盘 ，CPU 的 高 速 缓 在 一 般 
由 RAM 组 成 的 。 所 以 ， 选 项 C 
对 于 选项 D， 如 果 系 统 中 存 


圆 形 的 磁性 盘 片 装 在 一 个 方 的 密封 盒子 里 。 
盘 ， 简 称 固 盘 ) 是 用 固态 电子 存储 世 片 阵列 而 制 成 的 硬盘 ， 
芯片 、DRAM 芯片 ) 组 成 。ROM、RAM、 磁 盘 及 SSD 都 是 


三 | 
征 


髓 - 


网 


正确 。 
在 多 个 进程 ， 它 们 中 的 每 一 个 进程 都 占用 了 某 种 资源 而 又 都 


所 以 ， 本 题 的 答案 为 A。 
22. 答案 : A、D。 
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分 析 : 本 题 考 察 的 是 Linux 操作 系统 知识 。 

对 于 选项 A， 信 和 号 机 制 是 进程 之 间 相 互 传递 消息 的 一 种 方法 ， 信 和 号 全 称 为 软 中 断 信 和 号 、 
软 中 断 ， 其 实质 和 使 用 类 似 于 中 断 。 当 线性 访问 内 存 非 法 时 ， 会 产生 非法 内 存 访问 的 信和 号， 
当前 线程 会 进入 信和 号 处 理 函数 。 所 以 ， 选 项 A 正确 。 

对 于 选项 B, 可 以 使 用 myv 命令 在 相同 的 文件 系统 或 文件 系统 之 间 移 动 文件 。 不 管 是 在 一 
个 文件 系统 中 工作 ， 还 是 跨 文件 系统 工作 ，myv 命令 把 文件 复制 到 目标 处 并 删除 原文 件 。mv 
命令 在 新 文件 中 保存 最 新 数据 修改 的 时 间 、 最 新 访问 时 间 、 用 户 标 识 、 组 标识 和 原始 文件 的 
文件 方式 。 对 于 符号 链 路 ，myv 命令 仅 保存 该 链 路 本 身 的 所 有 者 和 组 。 所 以 ， 文 件 的 修改 时 间 
是 不 会 变化 的 。 所 以 ， 选 项 B 不 正确 。 

对 于 选项 C，ulimit 是 一 种 Linux 操作 系统 的 内 建功 能 ， 它 具有 一 套 参 数 集 ， 用 于 为 由 它 
生成 的 shell 进程 及 其 子 进程 的 资源 使 用 设置 限制 ， 是 一 种 简单 并 且 有 效 的 实现 资源 限制 的 方 
式 。ulimit 用 于 限制 shell 启动 进程 所 占用 的 资源 ， 文 持 以 下 各 种 类 型 的 限制 : 所 创建 的 内 核 
文件 的 大 小 、 进 程 数据 块 的 大 小 、shell 进程 创建 文件 的 大 小 、 内 存 锁 住 的 大 小 、 常 驻 内 存 集 
的 大 小 、 打 开 文 件 描述 符 的 数量 、 分 配 堆 栈 的 最 大 大 小 、CPU 时 间 、 单 个 用 户 的 最 大 线程 数 
以 及 shell 进程 所 能 使 用 的 最 大 虚拟 内 存 。 同 时 ， 它 支持 硬 资源 和 软 资 源 的 限制 。ulimit 命令 
的 格式 为 ulimit [options] [limitl，.-c 设置 的 是 core 文件 的 最 大 值 ， 而 不 是 函数 调用 栈 的 大 小 。 
所 以 ， 选 项 C 不 正确 。 

对 于 选项 D，malloc 函数 的 原型 为 void *malloc(int size)， 其 功能 是 向 系统 申请 分 配 指定 
size 个 字 节 的 内 存 空 间 。 返 回 类 型 是 void* 类 型 。void* 表示 未 确定 类 型 的 指针 。 所 以 ， 选 
项 D 正确 。 

所 以 ， 本 题 的 答案 为 A、D。 

23. 答案 : A。 

分 析 : 本 题 考 察 的 是 操作 系统 中 各 类 地 址 的 关系 。 

要 想 弄 明白 各 类 地 址 的 映射 ， 首 先 需 要 弄 懂 各 地 址 的 概念 。 

虚拟 地 址 指 的 是 由 程序 产生 的 由 段 选择 符 和 上 段 内 偏 移 地 址 两 个 部 分 组 成 的 地 址 。 这 两 部 
分 组 成 的 地 址 并 没有 直接 访问 物理 内 存 ， 而 是 要 通过 分 段 地 址 的 变换 机 构 处 理 或 映射 后 才 会 
对 应 到 相应 的 物理 内 存 地 址 。 

逻辑 地 址 指 的 是 由 程序 产生 的 与 段 相关 的 偏 移 地 址 部 分 。 

线性 地 址 指 的 是 虚拟 地 址 到 物理 地 址 变换 之 间 的 中 间 层 , 是 处 理 器 可 寻 址 的 内 存 空间 ( 称 
为 线性 地 址 空间 〉 中 的 地 址 。 程 序 代 码 会 产生 逻辑 地 址 ， 或 者 说 是 段 中 的 偏 移 地 址 ， 加 上 相 
应 段 的 基地 址 就 生成 了 一 个 线性 地 址 。 如 果 启 用 了 分 页 机 制 ， 那 么 线性 地 址 可 以 再 经 过 变换 
产生 物理 地 址 。 如 果 没 有 采用 分 页 机 制 ， 那 么 线性 地 址 就 是 物理 地 址 。 

物理 地 址 指 的 是 出 现在 CPU 外 部 地 址 总 线 上 的 寻 址 物理 内 存 的 地 址 信号 ,是 地 址 变换 的 
最 终结 果 。 

虚拟 地 址 到 物理 地 址 的 转化 方法 是 与 体系 结构 相关 的 。 一 般 来 说 ， 有 分 段 和 分 页 两 种 方 
式 。 以 义 86 CPU 为 例 ， 分 段 和 分 页 两 种 方式 都 是 支持 的 。Memory Management Unit (MMU， 
内 存 管理 单元 ) 负责 从 虚拟 地 址 到 物理 地 址 的 转化 。 逻 辑 地 址 是 段 标识 + 上 段 内 偏 移 量 的 形式 ， 
MMU 通过 查询 段 表 ， 可 以 把 逻辑 地 址 转化 为 线性 地 址 。 如 果 CPU 没有 开启 分 页 功能 ， 那 么 
线性 地 址 就 是 物理 地 址 ， 如 果 CPU 开启 了 分 页 功能 ，MMU 还 需要 查询 页 表 来 将 线性 地 址 转 


HH 
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化 为 物理 地 址 ， 逻 辑 地 址 -( 段 表 ) 一 线性 地 址 -〈 页 表 ) 一 物理 地 址 。 

不 同 的 逻辑 地 址 可 以 映射 到 同一 个 线性 地 址 上 ; 不同 的 线性 地 址 也 可 以 映射 到 同一 个 物 
理 地 址 上 ;所 以， 这 是 一 种 多 对 一 的 关系 。 另 外 ， 同 一 个 线性 地 址 ， 在 发 生 换 页 以 后 ， 也 可 
能 被 重新 装载 到 另外 一 个 物理 地 址 上。 所 以 ， 这 种 多 对 一 的 映射 关系 也 会 随时 间 发 生变 化 。 

分 段 机 制 就 是 把 虚拟 地 址 空间 中 的 虚拟 内 存 组 织 成 一 些 长 度 可 变 的 称 为 段 的 内 存 块 单 
元 。 分 页 机 制 把 线性 地 址 空间 和 物理 地 址 空间 分 别 划分 为 大 小 相同 的 块 ， 这 样 的 块 称 为 页 。 
通过 在 线性 地 址 空间 的 页 与 物理 地 址 空间 的 页 之 间 建 立 的 映射 ， 分 页 机 制 实现 线性 地 址 到 物 
里 地 址 的 转换 。 

通过 以 上 的 分 析 可 知 ， 选 项 A 是 正确 的 。 

所 以 ， 本 题 的 答案 为 A。 

24. 答案 : B。 

分 析 : 本 题 考 察 的 是 Java 基本 类 型 的 知识 。 

在 Java 语言 中 , 浮 点 数 默认 为 double， 如 果 要 给 float 型 变量 赋值 ， 需 要 在 浮 点 数 后 面 加 
上 f， 例 如 floati=0.62f。 所 以 ， 选 项 B 正确 。 

所 以 ， 本 题 的 答案 为 了 B。 

25. 答案 ， A。 

分 析 : 本 题 考察 的 是 线程 的 知识 。 

Thread.waitO 同 步 线程 ， 可 以 设置 超时 时 间 ， 函 数 原型 为 wait(long timeout) 和 wait(long 
timeout, int nanos)， 其 中 ，timeout 代表 最 大 的 等 待 怠 秒 数 ，nanos 代表 额外 的 等 竺 时间， 单位 
为 mss。 所以， 选项 A 正确 。 

所 以 ， 本 题 的 答案 为 A。 

26. 答案 : C。 

27. 答案 : B。 

28. 答案 : D。 

分 析 : 本 题 考察 的 是 移 位 运算 符 相 关 知 识 。 

函数 的 返回 值 与 传递 的 参数 无 关 。 本 题 中 ， 语 句 1<<5 相当 于 执行 了 2 的 5 次 方 ， 值 为 
32， 所 以 ， 最 终 的 结果 为 32-1=31。 所 以 ， 选 项 D 正确 。 

所 以 ， 本 题 的 答案 为 D。 


山 | 


Ya 


29. 答案 : D。 
30. 答案 ， A。 
31. 答案 : B。 
32. 答案 ， A、DD。 
33. 答案 : C。 


分 析 : 本 题 考察 的 是 完全 二 又 树 的 知识 。 

在 解答 本 题 前 ， 首 先 需 要 卉 懂 一 个 概念 ， 什 么 是 完全 二 又 树 ? 所 谓 完 全 二 又 树 是 指 除 树 
的 最 后 一 层 外 ， 每 一 层 上 的 结 点 数 均 达到 最 大 值 ， 且 在 最 后 一 层 上 只 缺少 右边 的 若干 结 点 的 
二 又 树 。 

通过 完全 二 又 树 的 定义 ， 可 以 引出 以 下 两 条 性 质 : 中 对 于 深度 为 的 有 n 个 结 点 的 二 又 
树 , 当 且 仅 当 其 每 一 个 结 点 都 与 深度 为 K 的 满 二 又 树 中 编号 从 1~n 的 结 点 一 一 对 应 时 , 此 二 
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又 树 称 为 完全 二 又 树 ; @ 一 棵 二 又 树 至 多 只 有 最 下 面 两 层 上 的 结 点 的 度数 可 以 小 于 2, 并且 最 
下 层 上 的 结 点 都 集中 在 该 层 最 左边 的 若干 位 置 上 ， 则 此 二 叉 树 为 完全 二 又 树 。 

假设 n0 是 度 为 0 的 结 点 总 数 〈 即 叶子 结 点 数 )，nl 是 度 为 1 的 结 点 总 数 ，n2 是 度 为 2 的 
结 点 总 数 ， 由 二 又 树 的 性 质 可 知 : n0=n2+1， 则 mn= n0+nl+n2〈 其 中 m 为 完全 二 又 树 的 结 点 总 


数 ), 由 上 述 公 式 把 n2 消去 得 n= 2n0+n1-1, 由 于 完全 二 又 树 中 度 为 1 的 结 点 数 只 有 两 种 可 能 : 


0 或 1， 由 此 得 到 n0=Cr+ly2 或 an0=n/2， 即 n0=Ln/2」]， 其 中 | | 表示 向 上 取 整 。 可 根据 完全 


二 又 树 的 结 点 总 数 计算 出 叶子 结 点 数 。 


本 题 中 , nm 的 值 为 100， 根 据 上 面 的 分 析 可 知 ，n0=50。 所 以 ， 度 为 0 的 结 点 有 50 个 ， 度 


为 1 的 结 点 有 1 个 ， 度 为 2 的 结 点 有 49 个 ， 二 又 树 前 k 


层 最 多 有 2^k-1 个 结 点 。 所 以 ，100 


个 结 点 二 又 树 高 度 为 7， 按 照 广度 优先 遍历 编号 ， 有 50 个 非 叶 子 结 点 ， 所 以 ， 最 小 的 叶子 结 


点 编号 为 51 。 
下 面 给 出 另外 一 种 求解 方法 : 
100 个 结 点 时 ， 二 又 树 高 度 为 7。 
7 层 包含 数据 个 数 为 100-(2^6-1)=37。 


CN 


结 点 应 该 为 32+19 = $1。 所 以 ， 选 项 C 正确 。 
所 以 ， 本 题 的 答案 为 C。 
34. 答案 : D。 
分 析 : 本 题 考 察 的 是 数据 结构 知识 。 


层 包 含 数 据 的 编号 为 32 一 63，6 层 中 前 19 个 数据 包含 子 树 (37/2=18.5)， 故 最 小 的 叶 


比 具 


XML (Extensible Markup Language， 可 扩展 标记 语言 ) 是 一 种 用 于 标记 电子 文件 只 
有 结构 性 的 标记 语言 。 在 XML 中 ,任何 的 起 始 标签 都 必须 有 一 个 结束 标签 ， 也 就 是 题目 中 所 


~ 


| 


提 到 的 结 点 闭合 。 由 此 可 以 类 比 数据 结构 课本 中 讲 过 的 括号 匹配 的 检验 ， 因 为 括号 都 是 成 对 
出 现 的 ， 一 个 左 括 弧 必 然 对 应 一 个 右 括 弧 ， 而 判断 插 号 是 否 匹 配 的 主要 思路 如 下 : 每 当 读 到 
一 个 括号 时 ， 如 果 是 右 括 号 ， 则 或 者 与 栈 顶 的 左 括号 匹配 ， 或 者 不 合法 ， 若 是 左 括号 ， 则 把 
左 括号 压 栈 。 所 以 ， 本 题 可 以 采用 同样 的 方式 来 判断 结 点 是 否 闭合 。 因 此 ， 栈 可 以 成 为 检验 


XML 结 点 是 否 闭合 的 数据 结构 。 所 以 ， 选 项 D 正确 。 
所 以 ， 本 题 的 答案 为 D。 
35. 答案 : B。 


分 析 : 本 题 考察 的 是 排序 算法 中 快速 排序 算法 的 知识 。 
快速 排序 是 目前 被 认为 最 好 的 一 种 内 部 排序 方法 。 快 速 排序 算法 处 理 的 最 好 情况 指 每 次 
都 是 将 待 排 序列 划分 为 均匀 的 两 部 分 ， 通 常 认 为 快速 排序 在 平均 情况 下 的 时 间 复 杂 度 为 


O(nlog n)。 但 是 ， 如 果 初 始 记 录 序 列 按 关 键 字 有 序 或 基本 有 序 ， 那 么 此 时 快速 排序 将 暗 化 为 


冒 泡 排 序 ， 其 时 间 复 杂 度 为 O(n 人 ^2)。 


那么 对 于 其 他 排序 算法 ， 当 序列 已 经 有 序 时 ， 又 是 哪 种 情况 呢 ? 无 论 原始 序列 中 的 元 素 


如 何 排列 ， 归 并 排序 和 堆 排 序 算 法 的 时 间 复 杂 度 都 是 Onlog n)。 插 入 排序 的 思想 是 将 一 个 新 


元 素 插入 已 经 排列 好 的 序列 中 。 如 果 在 数据 已 经 是 升序 的 情况 下 ， 新 元 素 具 需 插 入 到 序列 尾 
部 ， 这 就 是 插入 排序 的 最 好 情况 ， 此 时 ， 时 间 复 杂 度 为 O(n)。 所 以 ， 选 项 B 正确 。 


所 以 ， 本 题 的 答案 为 B。 
36. 答案 : D。 
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分 析 : 


本 题 考察 的 是 图 的 知识 。 


本 题 必须 弄 明 白 无 向 图 的 深度 优先 遍历 的 原理 。 其 实 ， 图 的 深度 优先 遍历 类 似 于 树 的 前 
序 遍 历 。 假设 给 定 无 向 图 G 的 初 态 是 所 有 顶点 均 未 曾 被 访问 过 , 深度 优先 遍历 过 程 是 这 样 的 : 


在 无 向 图 G 


FP 任 选 一 个 顶点 v 为 初始 日 


发 点 〈 源 点 )， 首先 访问 源 点 v， 并 将 其 标记 为 已 访问 


过 , 然后 , 依次 从 源 点 v 出 发 , 搜索 源 点 v 的 每 个 相 邻 结 点 w。 如 果 结 点 w 未曾 被 访问 过 ， 


那么 以 结 点 w 为 新 的 蝇 


发 点 继续 进行 深度 优先 遍历 ， 直 至 图 中 所 有 和 源 点 v 有 路 径 相 通 


的 顶点 ( 亦 称 为 从 源 点 可 达 的 顶点 ) 均 已 被 访问 为 止 。 如 果 此 时 图 中 仍 有 未 访问 的 顶点 ， 
则 另 选 一 个 尚未 访问 的 顶点 作为 新 的 源 点 重复 


为 目 


图 的 深度 优先 壳 历 的 伪 代 码 如 下 : 


上述 过 程 ， 直 至 图 中 所 有 项 点 均 已 被 访问 


1) 访问 顶点 v，visited[v]=1; /算法 执行 前 visited[n]=0 


2) w= 顶点 v 的 第 一 个 邻接 点 ; 
3) while (w 存在 ) 
让 Cw 未 被 访问 ) 
从 顶点 w 出 发 递归 执行 该 
w= 顶点 v 的 下 一 个 邻接 点 ; 


算法 ; 


与 深度 优先 遍历 相对 应 的 是 广度 优先 吉 历 ， 图 的 广度 优先 遍历 算法 是 一 个 分 层 搜 索 的 过 


接点 ”被 访问 ， 


顶点 的 邻接 顶点 。 


1) 顶点 v 入 队列 。 

2) 如 果 队 列 非 空 ， 则 继续 执行 ， 
3) 出 队列 取得 队 头顶 点 v， 访 问 顶 点 v 并 标记 顶点 v 已 被 访问 。 
4) 查找 顶点 v 的 第 一 个 邻接 顶点 col。 
5) 如 果 v 的 邻接 顶点 col 未 被 访问 过 的 ， 则 col 入 队列 。 

6) 继续 查找 顶点 v 的 另 一 个 新 的 邻接 顶点 col1， 转 到 步骤 5)。 


7) 直到 顶点 v 的 所 有 未 被 访问 过 


程 ， 和 树 的 层 序 裔 历 算法 相似 ， 以 顶点 v 为 起 始点 ， 由 近 至 远 ， 依 次 访问 和 v 有 路 径 相 通 而 


且 路 径 长 度 为 1，2，… 的 顶点 。 为 了 使 “ 先 被 访问 顶点 的 邻接 点 ” 先 于 “后 被 访问 项 点 的 邻 
它 需要 一 个 队列 以 保持 遍历 过 的 顶点 顺序 ， 以 便 按 出 队 的 顺序 再 去 访问 这 些 


基体 而 言 ， 图 的 广度 优先 遍历 的 步 又 如 下 所 示 : 


人 否则， 算法 结束 。 


其 体 而 言 ， 图 的 广度 优先 遍历 的 伪 代 码 如 下 : 


邻接 点 处 理 完 。 转 到 步骤 2)。 


1) 初始 化 队列 Q; visited[n]=0; 


2) 访问 顶点 v;， visited[v]=1;， 顶点 v 入 队列 Q:; 


3) while (队列 Q 非 空 ) 


v= 队 列 Q 的 对 头 元 素 出 队 ; 
w= 顶点 v 的 第 一 个 邻接 点 ; 


while (w 存在 ) 
如 果 w 未 访问 ， 则 
Visited[w]=1; 
顶点 w 入 队列 Q; 


访问 顶点 w; 


w= 顶 点 v 的 下 一 个 邻接 点 ; 
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本 题 中 ， 按 照 上 述 方法 可 知 ， 选 项 D 正确 。 

所 以 ， 本 题 的 答案 为 D。 

二 、 问 答题 

1. 答案 : 在 多 任务 系统 中 ， 在 同一 时 刻 通常 会 有 多 个 任务 处 于 活动 状态 ， 操 作 系 统 此 时 
就 需要 对 资源 进行 管理 ， 在 任务 间 实 现 资源 CPU、 内存 等 ) 的 共享 。 任 务 调度 是 指 基于 给 
定时 间 点 、 给 定时 间 间 隔 或 者 给 定 执行 次 数 自动 执行 任务 。 轮 询 任 务 调度 与 抢占 式 任务 调度 
的 区 别 在 于 抢占 式 调度 中 优先 级 高 的 任务 可 以 抢占 CPU， 而 轮 询 的 不 能 。 
具体 而 言 ， 轮 询 调度 的 原理 是 每 一 次 把 来 自用 户 的 请 求 轮流 分 配给 内 部 服务 器 ， 从 1 开 
始 ， 直 到 N〔 内 部 服务 器 个 数 )， 然 后 重新 开始 循环 。 只 有 在 当前 任务 主动 放弃 CPU 控制 权 
的 情况 下 (比如 任务 挂 起 )， 才 允许 其 他 任务 (包括 高 优先 级 的 任务 〉 控制 CPU。 其 优点 是 简 
洁 性 ， 无 须 记 录 当 前 所 有 连接 的 状态 ， 所 以 ， 它 是 一 种 无 状态 调度 ， 但 缺点 是 不 利于 后 面 的 
请 求 及 时 得 到 响应 。 抢 占 式 调度 允许 高 优先 级 的 任务 打 断 当前 执行 的 任务 ， 抢 占 CPU 的 控制 
权 。 这 有 利于 后 面 的 高 优先 级 的 任务 也 能 及 时 得 到 响应 。 但 实现 相对 较 复 杂 ， 并 且 可 能 出 现 
低 优 先 级 的 任务 长 期 得 不 到 调度 的 情况 。 

2. 答案 : 锁 是 网 络 数据 库 中 的 一 个 非常 重要 的 概念 ， 当 多 个 用 户 同时 对 数据 库 并 发 操作 
时 ， 会 带 来 数据 不 一 致 的 问题 ， 所 以 ， 锁 主要 用 于 多 用 户 环境 下 保证 数据 库 完 整 性 和 一 致 性 。 
以 商场 的 试 衣 间 为 例 ， 每 个 试 衣 间 都 可 供 多 个 消费 者 使 用 ， 因 此 ， 可 能 出 现 多 个 消费 者 同时 
需要 使 用 试 衣 间 试 衣服 。 为 了 避免 冲突 ， 试 衣 间 装 了 锁 ， 某 一 个 试 衣服 的 人 在 试 衣 间 里 把 锁 
锁 住 了 ， 其 他 顾客 就 不 能 再 从 外 面 打 开 了 ， 只 能 等 待 里 面 的 顾客 试 完 衣 服 ， 从 里 面 把 锁 打 开 ， 
外 面 的 人 才能 进去 。 

各 种 大 型 数据 库 所 采用 的 锁 的 基本 原理 是 一 致 的 ， 但 在 具体 实现 上 各 有 差别 。 在 数据 库 
中 加 锁 时 ， 除 了 可 以 对 不 同 的 资源 加 锁 ， 还 可 以 使 用 不 同 程度 的 加 锁 方 式 ， 即 锁 有 多 种 模式 : 
共享 锁 、 修 改 锁 、 独 占 锁 、 结 构 锁 、 意 向 锁 及 批量 修改 锁 等 。 

以 下 将 分 别 对 这 些 种 类 的 锁 模 式 进 行 解 释 与 分 析 。 

(1) 共享 锁 
* 享 锁 也 称 为 S (Share Lock) 锁 ， 用 于 所 有 的 只 读数 据 操 作 。 共 享 锁 是 非 独 占 的 ， 允 许 
多 个 并 发 事务 读 取 其 锁定 的 资源 。 它 具有 以 下 性 质 : 多 个 事务 可 封锁 一 个 共享 页 ;任何 事务 
都 不 能 修改 该 页 ; 通常 是 该 页 被 读 取 完毕 ，S 锁 立 即 被 释放 。 在 SQL Server 中 ， 默 认 情 况 下 ， 
数据 被 读 取 后 ， 立 即 释 放 共 享 锁 。 例 如 ， 执 行 查询 语句 “SELECT* FROM my table” 时 ， 首 
先 锁定 第 一 页 ， 读 取 之 后 ， 释 放 对 第 一 页 的 锁定 ， 然 后 锁定 第 二 页 。 这 样 ， 就 允许 在 读 操 作 
过 程 中 ， 修 改 未 被 锁定 的 第 一 页 。 但是， 事务 隔离 级 别 连接 选项 设置 和 SELECT 语句 中 的 锁 
定 设置 都 可 以 改变 SQL Server 的 这 种 默认 设置 。 例 如 ， 语 名 “SELECT * FROM my _table 
HOLDLOCK” 就 要 求 在 整个 查询 过 程 中 ， 保 持 对 表 的 锁定 ， 直 到 查询 完成 才 释 放 锁 定 。 

(2) 排他 锁 

排他 锁 (Exclusive Lock) 也 叫 写 锁 (X 锁 )， 表 示 对 数据 进行 写 操作 。 如 果 一 个 事务 对 对 
象 加 了 排他 锁 ， 其 他 事务 就 不 能 再 给 它 加 任何 锁 了 【〔 某 个 顾客 把 试 衣 间 从 里 面 反锁 了 ， 其 他 
顾客 想 要 使 用 这 个 试 衣 间 ， 就 只 有 等 待 锁 从 里 面 给 打开 了 )。 排 他 锁具 有 以 下 几 点 性 质 : 仅 允 
许 一 个 事务 封锁 此 页 ， 其 他 任何 事务 必须 等 到 X 锁 被 释放 才能 对 该 页 进行 访问 ; X 锁 一 直到 
事务 结束 才能 被 释放 。 
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产生 排他 锁 的 SQL 语句 如 下 所 示 : select * from ad_plan for update; 

(3) 更 新 锁 

更 新 锁 〈 也 叫 U 锁 ) 在 修改 操作 的 初始 化 阶段 用 来 锁定 可 能 要 被 修改 的 资源 ， 这 样 可 
以 避免 使 用 共享 锁 造 成 的 死 锁 现象 。 因 为 当 使 用 共享 锁 时 ， 修 改 数据 的 操作 分 为 两 步 ， 首 
先 获 得 一 个 共享 锁 ， 读 取 数 据 ， 然 后 将 共享 锁 升 级 为 排他 锁 ， 再 执行 修改 操作 。 这 样 如 果 
有 两 个 或 多 个 事务 同时 对 一 个 事务 申请 了 共享 锁 ， 在 修改 数据 的 时 候 ， 这 些 事务 都 要 将 共 
享 锁 升级 为 排他 锁 。 这 时 ， 这 些 事务 都 不 会 释放 共享 锁 而 是 一 直 等 待 对 方 释放 ， 这 样 就 造 
成 了 死 锁 。 如 果 一 个 数据 在 修改 前 直接 申请 更 新 锁 ， 在 数据 修改 的 时 候 再 升级 为 排他 锁 ， 
就 可 以 避免 死 锁 。 

新 锁具 有 以 下 性 质 : 用 来 预定 要 对 此 页 施加 和 锁 ， 它 允许 其 他 事务 读 ， 但 不 允许 再 施 
加 锁 或 X 锁 ; 当 被 读 取 的 页 将 要 被 更 新 时 ， 则 升级 为 X 锁 ; U 锁 一 直到 事务 结束 时 才能 被 
释放 。 

从 程序 员 的 角度 看 ， 分 为 乐观 锁 和 悲观 锁 。 悲 观 锁 (Pessimistic Lock)， 顾 名 思 义 ， 就 是 
很 翡 观 ， 每 次 去 取 数 据 的 时 候 都 认为 别人 会 修改 ， 所 以 ， 每 次 在 拿 数据 的 时 候 都 会 上 锁 ， 这 
样 别 人 想 拿 这 个 数据 就 会 block〈 阻 塞 )， 直 到 它 拿 到 锁 。 传 统 的 关系 型 数据 库 里 就 用 到 了 很 
多 这 种 锁 机 制 ,例如 行 锁 、 表 锁 、 读 锁 及 写 锁 等 ,它们 都 是 在 操作 之 前 先 上 锁 。 乐 观 锁 (Optimistic 
Lock)， 顾 名 思 义 ， 就 是 很 乐观 ， 每 次 去 拿 数据 的 时 候 都 认为 别人 不 会 修改 ， 所 以 不 会 上 锁 ， 
但 是 在 更 新 的 时 候 会 判断 一 下 在 此 期 间 别 人 有 没有 去 更 新 这 个 数据 , 可 以 使 用 版 本 号 等 机 制 。 
乐观 锁 适 用 于 多 读 的 应 用 类 型 ， 这 样 可 以 提高 吞吐 量 ， 像 数据 库 如 果 提 供 类 似 于 
write_condition 机 制 的 ， 其 实 都 是 提供 的 乐观 锁 。 

3. 答案 ; 

(1) 进程 和 线程 的 关系 

1) 一 个 线程 上 只 能 属于 一 个 进程 ， 而 一 个 进程 可 以 有 多 个 线程 ， 但 至 少 有 一 个 线程 。 

2) 资源 分 配给 进程 ， 同 一 进程 的 所 有 线程 共享 该 进程 的 资源 。 

3) 处 理 机 分 给 线程 ， 即 真正 在 处 理 机 上 运行 的 是 线程 。 

4) 线程 在 执行 过 程 中 ， 需 要 协作 同步 。 不 同 进程 的 线程 间 要 利用 消息 通信 的 办 法 实现 同 
步 。 线 程 指 的 是 进程 内 的 一 个 执行 单元 ， 也 是 进程 内 的 可 调度 实体 。 

进程 和 线程 的 相同 点 如 下 : 

1) 二 者 都 具有 JID、 一 组 寄存 器 、 状 态 、 优 先 级 以 及 所 要 遵循 的 调度 策略 。 

2) 每 个 进程 都 有 一 个 进程 控制 块 ， 线 程 也 拥有 一 个 线程 控制 块 。 

3) 线程 和 子 进 程 共享 父 进 程 中 的 资源 ; 线程 和 子 进程 独立 于 它们 的 父 进程 ， 竞 争 使 用 处 
理 器 资源 ; 线程 和 子 进 程 的 创建 者 可 以 在 线程 和 子 进程 上 实行 某 些 控制 ， 例 如 ， 创 建 者 可 以 
取消 、 挂 起 、 继 续 和 修改 线程 和 子 进程 的 优先 级 ;线程 和 子 进 程 可 以 改变 其 属性 并 创建 新 的 
资源 。 

进程 和 线程 的 不 同 点 如 下 : 

1) 线程 是 进程 的 一 部 分 ， 一 个 没有 线程 的 进程 是 可 以 被 看 作 单 线程 的 ， 如 果 一 个 进 
程 内 拥有 多 个 线程 ， 进 程 的 执行 过 程 不 是 一 条 线 〈 线 程 ) 的 ， 而 是 多 条 线 〈 线 程 ) 共同 完 
成 的 。 

2) 启动 一 个 线程 所 花费 的 空间 远 远 小 于 启动 一 个 进程 所 花费 的 空间 ， 而 且 ， 线 程 间 彼此 
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切换 所 需 的 时 间 也 远 远 小 于 进程 间 切 换 所 需要 的 时 间 。 
3) 系统 在 运行 的 时 候 会 为 每 个 进程 分 配 不 同 的 内 存 区 域 , 但 是 不 会 为 线程 分 配 内 存 〈 线 


程 所 使 用 的 资源 是 它 所 属 的 进程 的 资源 )， 同 一 个 进程 内 的 线程 可 以 共享 进程 的 资源 。 对 不 同 
进程 来 说 ， 它 们 具有 独立 的 数据 空间 ， 要 进行 数据 的 传递 只 能 通过 通信 的 方式 进行 ， 这 种 方 


式 不 仅 费 时 ， 而 且 很 不 方便 。 而 一 个 线程 的 数据 可 以 直接 为 其 他 线程 所 用 ， 这 不 仪 快捷 ， 而 


且 方 便 。 


4) 与 进程 的 控制 表 PCB 相似 ,线程 也 有 自己 的 控制 表 TCB, 但 是 TCB 中 所 保存 的 线程 
状态 远 比 PCB 表 中 的 少 。 


5) 进程 是 系统 所 有 资源 分 配 时 候 的 一 个 基本 单位 ， 拥 有 一 个 完整 的 虚拟 空间 地 址 ， 并 不 


依赖 线程 而 独立 存在 。 


(2) 多 线程 的 优 缺 点 
优点 : 无 须 跨 进程 边界 ， 程序 逻辑 和 控制 方式 简单 ， 所 有 线程 可 以 直接 共享 内 存 和 变量 


等 ; 线程 方式 消耗 的 总 资源 比 进程 方式 少 。 


缺点 : 每 个 线程 与 主 程序 共用 地 址 空间 ， 受 限于 2GB 地 址 空间 ; 线程 之 间 的 同步 和 加 锁 


控制 比较 麻烦 ， 一 个 线程 的 崩 江 可 能 影响 到 整个 程序 的 稳定 性 ， 到 达 一 定 的 线程 数 程度 后 ， 


即使 再 增加 CPU 也 无 法 提高 性 能 ， 例 如 Windows Server 2003， 大 约 是 1500 个 线程 数 就 快 到 
极限 了 线程 堆栈 设 定 为 1IM)， 如 果 设 定 线程 堆栈 为 2M， 还 达 不 到 1500 个 线程 总 数 ; 线程 


能 够 提高 的 总 性 能 有 限 ， 而 且 线程 多 了 之 后 ， 线 程 本 身 的 调度 也 比较 麻烦 ， 需 要 消耗 较 多 的 


CPU。 


(3) 多 进程 的 优 缺 点 
优点 : 每 个 进程 互相 独立 ， 不 影响 主 程序 的 稳定 性 ， 子 进程 骨 溃 没关系 ; 通过 增加 CPU， 


就 可 以 容易 扩充 性 能 ; 


可 以 尽量 减少 线程 加 锁 /解锁 的 影响 ， 极 大 提高 性 能 ， 就 算是 线程 运行 


的 模块 算法 效率 低 也 没关系 ; 每 个 子 进程 都 有 2GB 地 址 空间 和 相关 资源 ， 总 体能 够 达到 的 性 


能 上 限 非常 大 。 


缺点 : 逻辑 控制 复杂 ， 需 要 和 主 程序 交互 ， 需 要 跨 进 程 边界 ， 如 果 有 大 数据 量 传送 ， 就 
不 适合 ， 适 合 于 小 数据 量 传送 、 密 集运 算 多 进程 调度 开销 比较 大 ， 最 好 是 多 进程 和 多 线程 结 


合 ， 即 根据 实际 的 需要 ， 每 个 CPU 开启 一 个 子 进 程 ， 这 个 子 进程 开启 多 线程 可 以 为 若干 同类 
型 的 数据 进行 处 理 。 当 然 ， 也 可 以 利用 多 线程 + 多 CPU+ 轮 询 方式 来 解决 问题 。 


方法 和 手段 是 多 术 


FE 的 ， 关 键 是 选择 实现 起 来 方便 又 能 够 满足 要 求 ， 代 价 也 合适 的 方法 。 


S53 者 有 : 放 、 东 知名 互联 网 游戏 公司 校园 招聘 运 维 


一 、 单 项 选择 题 
1. 答案 : D。 


开发 岗 笔 试题 


分 析 : 本 题 考 察 的 是 Linux 操作 系统 知识 。 
对 于 选项 A，w 命令 用 来 显示 当前 登录 的 用 户 信息 。 所 以 ， 选 项 A 错误 。 


对 于 选项 B，top 命 


HV 令 用 来 实时 显示 系统 中 各 个 进程 的 资源 占用 状况 。 所 以 ， 选 项 B 错误 。 
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对 于 选项 C，ps 命令 用 来 列 出 系统 中 当前 运行 的 那些 进程 。 所 以 ， 选 项 C 错误 。 

对 于 选项 D，uptime 命令 主要 用 于 获取 主机 运行 时 间 和 查询 Linux 系统 负载 等 信息 ， 可 
以 显示 系统 现在 时 间 、 系 统 已 经 运行 了 多 长 时 间 、 目前 有 多 少 登 录用 户 、 系 统 在 过 去 的 1min、 
5min 和 15min 内 的 平均 负载 。 所 以 ， 选 项 D 正确 。 

所 以 ， 本 题 的 答案 为 D。 

2. 答案 : B。 

分 析 : 本 题 考 察 的 是 操作 系统 知识 。 

进程 的 状态 有 两 种 划分 方式 ， 三 态 模型 与 五 态 模型 。 

1) 三 态 模 型 ， 运行 态 、 就 绪 态 、 阻 塞 ( 等 待 》 态 。 

2) 五 态 模 型 : 新 建 态 、 就 绪 态 、 运 行 态 、 阻 塞 态 、 终 止 态 。 

下 面 重 点 介绍 三 态 模型 中 的 各 个 状态 : 

1) 运行 态 : 表明 这 个 进程 正在 处 理 器 上 运行 。 

2) 就 绪 态 : 当 一 个 进程 获取 到 了 除 处 理 器 以 外 的 所 有 一 切 资源 ， 一 旦 处 理 器 可 用 ， 这 个 
进程 就 可 以 执行 ， 处 在 这 个 状态 下 的 进程 的 状态 为 就 绪 状 态 。 

3) 阻塞 态 : 当 一 个 进程 正在 等 待 某 一 件 事 发 生 《〈 比 如 IO 事件 ) 而 暂停 运行 ， 就 算 处 理 
器 可 用 ， 这 个 进程 也 无 法 执行 ， 处 在 这 个 状态 下 的 进程 的 状态 为 阻塞 状态 。 
所 以 ， 本 题 的 答案 为 B。 

3. 答案 : C。 

分 析 : 本 题 考 察 的 是 Linux 操作 系统 知识 。 

在 Linux 系统 中 , umask 主要 用 来 设置 用 户 创建 文件 的 默认 权限 (设置 的 是 权限 的 补 码 )。 
在 计算 新 创建 文件 的 默认 权限 时 ， 首 先 写 出 文件 最 大 的 权限 模式 ， 然 后 从 这 个 模式 中 拿 志 
umask 就 可 以 得 到 新 创建 文件 的 默认 权限 。Linux 操作 系统 中 的 文件 有 三 种 权限 : T〈 读 )、w 
( 写 ) 和 x 执行 )， 分 别 用 数字 4、2 和 1 代表 。 对 于 新 创建 的 文件 来 说 ， 最 大 的 权限 是 6， 
因为 新 创建 的 文件 不 能 有 执行 权限 ， 只 能 在 创建 后 通过 chmod 命令 (chmod 是 Linux 系统 管 
理 员 最 常用 到 的 命令 之 一 ， 它 用 于 改变 文件 或 目录 的 访问 权限 ) 给 文件 增加 执行 权限 。 因 此 ， 
新 创建 的 文件 的 最 大 权限 模式 为 666(-rw-rw-rw-)， 由 于 unmask 设置 为 244， 因 此 ， 从 666 
中 拿 去 244 后 变 为 422 (-r---w--w--)。 所 以 ， 选 项 C 正确 。 

所 以 ， 本 题 的 答案 为 C。 

4. 答案 : B。 

分 析 : 本 题 考 察 的 是 计算 机 网 络 与 通信 知识 。 

对 于 选项 A， 随 着 网 络 技术 的 不 断 发 展 ， 卫 地 址 紧缺 已 经 是 一 个 非常 突出 的 问题 ， 网 络 
地 址 转换 正 是 为 了 解决 这 个 问题 而 出 现 的 ， 网 络 地 址 转换 的 作用 是 把 内 网 的 私有 地 址 ， 转 化 
成 外 网 的 公有 地 址 ， 使 得 内 部 网 络 上 的 (被 设置 为 私有 了 P 地 址 的 ) 主机 可 以 访问 nternet。 当 
大 量 的 内 部 主机 只 能 使 用 少量 的 合法 的 外 部 地 址 时 ， 此 时 就 可 以 使 用 NAT (Network Address 
Translation， 网 络 地 址 转换 ) 把 内 部 地 址 转化 成 外 部 地 址 。 所 以 ， 选 项 A 正确 。 

对 于 选项 B， 地 址 转换 实现 了 对 用 户 透明 的 网 络 内 部 地 址 的 分 配 ， 而 不 是 外 部 。 所 以 ， 
选项 B 错误 。 

对 于 选项 C， 地 址 转换 只 会 对 内 网 与 公 网 地 址 进行 映射 ， 不 会 影响 其 他 功能 。 所 以 ， 选 
项 C 正确 。 
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对 于 选项 D， 由 于 网 络 内 部 计算 机 在 访问 Internet 的 时 候 都 会 被 映射 为 一 个 公 网 地 址 ， 因 
此 ， 并 没有 把 计算 机 实际 的 地 址 暴露 在 Internet 中 ， 而 是 提供 了 一 定 的 “隐私 ”。 所 以 ， 选 项 
D 正确 。 

所 以 ， 本 题 的 答案 为 B。 

5. 答案 : C、D。 

分 析 : 本 题 考察 的 是 计算 机 网 络 与 通信 知识 。 

本 题 中 ，/27 表明 卫 地 址 的 子 网 号 为 27 位 《〈 子 网 掩 码 : 11111111.11111111.11111111. 
11100000)， 然 后 把 IP 地 址 与 这 个 子 网 掩 码 执行 按 位 与 〈&) 操作 ， 就 可 以 得 到 子 网 号 ， 子 网 
号 相同 的 就 在 一 个 子 网 内 。 由 于 卫 地 址 前 面 几 位 都 是 192.168.1， 因 此 ， 只 需要 考虑 最 后 一 位 
即 可 。 

题目 中 卫 地 址 最 后 一 个 位 的 十 进 制 表示 为 110， 其 对 应 的 二 进 制 位 表示 为 01101110， 与 
子 网 掩 码 与 的 结果 为 01100000, 而 94 的 二 进 制 为 01011110, 与 子 网 掩 码 与 的 结果 为 01000000; 
96 的 二 进 制 为 01100000， 与 子 网 掩 码 与 的 结果 为 01100000; 124 的 二 进 制 为 01111100, 与 子 
网 掩 码 与 的 结果 为 01100000; 126 的 二 进 制 为 01111110， 与 子 网 掩 码 与 的 结果 为 01100000。 
由 此 可 见 ， 选 项 C 与 选项 D 的 子 网 号 与 题目 给 出 的 卫 地 址 的 子 网 号 相同 ， 因 此 ， 它 们 属于 
同一 个 子 网 。 

所 以 ， 本 题 的 答案 为 C、D。 

6. 答案 : B。 

分 析 : 本 题 考 察 的 是 计算 机 网 络 与 通信 知识 。 

PING 命令 主要 用 来 检测 网 络 是 否 连通 , 使 用 方式 为 : ping ip 地 址 。 底 层 实 现 的 原理 为 PING 
发 送 一 个 ICMPECHO 包 ; 接收 ICMP echo (ICMP 回声 应 答 )。 因 此 ， 选 项 B 正确 。 

对 于 选项 A，ICMP (Internet Control Message Protocol，Internet 控制 报 文 协议 ) 重 定向 报 
文 是 ICMP 控制 报 文 中 的 一 种 。 在 特定 的 情况 下 ， 当 路 由 器 检测 到 一 台 机 器 使 用 非 优 化 路 
的 时 候 ， 它 会 向 该 主机 发 送 一 个 ICMP 重 定向 报 文 ， 请 求 主 机 改变 路 由 。 路 由 器 也 会 把 初始 
数据 报 文 向 它 的 目的 地 转发 。 因 此 ， 选 项 A 错误 。 

对 于 选项 C， 源 抑制 报 文 《Source Quench Message) 一 般 被 接收 设备 用 于 帮助 防止 它们 
的 缓存 溢出 。 接 收 设备 通过 发 送 源 抑制 报 文 来 请 求 源 设 备 降低 当前 的 数据 发 送 速度 。 因 此 ， 
选项 C 错误 。 

对 于 选项 D， 当 数据 包 无 法 被 转发 到 目标 结 点 或 者 上 层 协议 时 ， 路 由 器 或 者 目标 结 点 发 
送 ICMPv6 目标 不 可 达 差 错 报 文 。 因此， 选项 DD 错误 。 

所 以 ， 本 题 的 答案 为 B。 

7. 管 案 : C。 

分 析 : 本 题 考察 的 是 计算 机 网 络 与 通信 知识 。 

传输 层 协议 主要 有 TCP 协议 与 UDP 协议 。UDP (User Datagram Protocol， 用 户 数据 报 协 
议 ) 提供 无 连接 的 通信 ， 不 能 保证 数据 包 被 发 送 到 目标 地 址 ， 典 型 的 即时 传输 少量 数据 的 应 
用 程序 通常 使 用 UDP; 而 TCP (Transmission Control Protocol， 传 输 探 制 协议 ) 协议 是 一 种 面 
向 连接 〈 连 接 导 向 ) 的 、 可 靠 的 、 基 于 字 节 流 的 通信 协议 ， 它 为 传输 大 量 数 据 或 为 需要 接收 
数据 许可 的 应 用 程序 提供 连接 定向 和 可 靠 的 通信 。 

TCP 与 UDP 都 是 一 种 常用 的 通信 方式 , 在 特定 的 条 件 下 发 挥 不 同 的 作用 。 有 具体 而 言 , TCP 
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和 UDP 的 区 别 主要 表现 为 以 下 儿 个 方面 : 

1) TCP 是 面向 连接 的 传输 控制 协议 ， 而 UDP 提供 的 是 无 连接 的 数据 报 服务 。 

2) TCP 具有 高 可 靠 性 ， 确 保 传 输 数 据 的 正确 性 ， 不 出 现 丢失 或 乱 序 ，UDP 在 传输 数据 
前 不 建立 连接 ， 不 对 数据 报 进行 检查 与 修改 ， 无 须 等 待 对 方 的 应 答 ， 所 以 ， 会 出 现 分 组 丢失 、 
重复 、 乱 序 ， 应 用 程序 需要 负责 传输 可 靠 性 方面 的 所 有 工作 。 

3) TCP 对 系统 资源 要 求 较 多 ，UDP 对 系统 资源 要 求 较 少 。 

4) UDP 具有 较 好 的 实时 性 ， 工 作 效 率 较 TCP 高 。 

5) UDP 段 结构 比 TCP 的 段 结构 简单 ， 因 此 ， 网 络 开销 也 小 。 

6) TCP 通过 滑动 窗口 来 控制 发 送 的 速率 ，UDP 没有 使 用 滑动 窗口 。 

7) UDP 主要 用 来 传输 视频 、 音 频 等 可 靠 性 要 求 低 的 情况 ， 而 TCP 主要 用 于 数据 传输 与 
文件 下 载 等 可 靠 性 要 求 高 的 情况 。 
| 此 可 见 ，UDP 提供 了 高 的 传输 效率 。 所 以 ， 选 项 C 正确 。 

所 以 ， 本 题 的 答案 为 C。 

8. 答案 : D。 

分 析 : 本 题 考 察 的 是 计算 机 网 络 与 通信 知识 。 

TCP 是 一 种 面向 连接 的 、 可 靠 的 、 基 于 字 节 流 的 传输 层 通 信 协 议 ， 主 要 通过 如 下 一 些 方 
式 实现 可 靠 传输 : 

当 TCP 发 出 一 个 段 后 ， 它 启动 一 个 定时 器 ， 等 待 目 的 端 确认 收 到 这 个 报 文 段 。 如 果 不 能 
及 时 收 到 一 个 确认 ,将 重 发 这 个 报 文 段 。 当 TCP 收 到 发 自 TCP 连接 另 一 端的 数据 时 ， 它 将 发 
送 一 个 确认 。 

TCP 将 保持 其 首部 和 数据 的 检验 和 。 这 是 一 个 端 到 端的 检验 和 ， 目 的 是 检测 数据 在 传输 
过 程 中 的 任何 变化 。 如 果 收 到 段 的 检验 和 有 差错 ，TCP 将 丢弃 这 个 报 文 段 ， 同 时 ， 不 确认 收 
到 此 报 文 段 。 

1 于 TCP 报 文 段 作为 卫 数据 报 来 传输 ， 而 卫 数据 报 的 到 达 可 能 会 失 序 ， 因 此 ，TCP 报 
文 段 的 到 达 也 可 能 会 失 序 。 因 此 ，TCP 将 对 收 到 的 数据 进行 重新 排序 ， 将 收 到 的 数据 以 正确 
的 顺序 交 给 应 用 层 ， 这 就 需要 对 报 文 进行 编号 ， 以 确定 报 文 的 顺序 。 

| 此 可 见 ， 选 项 DD 正确 。 
对 于 选项 A， 封 装 是 为 了 提高 传输 效率 ， 当 个 别 包 传输 失败 后 ， 只 需要 重 传 失败 的 包 即 
可 ， 如 果 没 有 把 一 个 大 的 包 封 装 成 多 个 小 的 包 ， 每 当 一 个 包 出 错 的 时 候 ， 都 需要 重 发 整个 包 。 
所 以 ， 选 项 A 错误 。 

对 于 选项 B， 拥 塞 控制 的 目的 是 防止 过 多 的 数据 注入 到 网 络 中 ， 这 样 可 以 使 网 络 中 的 路 
由 器 或 链 路 不 致 过 载 。 所 以 ， 选 项 B 错误 。 

对 于 选项 C，TCP 是 面向 连接 的 服务 ， 而 UDP 才 是 面向 无 连接 的 服务 。 所 以 ， 选 项 C 
背 误 。 

所 以 ， 本 题 的 答案 为 D。 

9. 答案 : A。 

分 析 : 本 题 考 察 的 是 对 bash 变量 的 理解 。 

bash 是 一 个 为 GNU (CGNU is Not Unix 的 递归 缩写 ) 计划 编写 的 Unix shell， 它 的 名 字 是 
Bourne-Again Shell 的 缩写 ， 它 是 大 多 数 Linux 系统 以 及 Mac OS X v10.4 默认 的 shell， 能 运行 


ey 
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于 大 多 数 Unix 风格 的 操作 系统 之 上 ， 甚 至 被 移植 到 了 Microsoft Windows 上 的 Cygwin 系统 
， 以 实现 Windows 的 POSIX 虚拟 接口 。 此 外 ， 它 也 被 DJGPP 项 目 移植 到 了 MS-DOS 上 。 

bash 的 命令 语法 是 Bourne shell 命令 语法 的 超 集 。 本 题 中 ,对 于 选项 A， 用 来 表示 执行 
bash 程序 时 命令 行 参数 的 个 数 。 所 以 ， 选 项 A 正确 。 
对 于 选项 B，$$ 用 来 表示 当前 脚本 运行 的 进程 ID。 所 以 ， 选 项 B 错误 。 

对 于 选项 C，$@ 用 来 表示 参数 列表 。 所 以 ， 选 项 C 错误 。 

对 于 选项 D，$? 命 令 表示 函数 或 者 脚本 自身 的 退出 状态 ， 用 于 检查 上 一 个 命令 、 函 数 或 
者 脚本 执行 是 否 正 确 。 所 以 ， 选 项 DD 错误 。 

所 以 ， 本 题 的 答案 为 A。 

10. 答案 : C。 

分 析 : 本 题 考察 的 是 bash 中 对 重 定 向 的 理解 。 

输出 可 以 分 为 标准 输出 和 标准 错误 输出 ， 其 中 2 代表 标准 错误 输出 ，1 代表 标准 输出 。 
重 定 向 有 两 种 方式 : >demo.log 与 >>demo.log。 其 中 ，>demo.log 把 标准 输出 流 重 定向 到 
demo.log 文件 中 ,这 种 方式 会 清空 demo.log 中 的 内 容 ， 而 >>demo.log 则 只 把 标准 输出 重 定向 到 
demo.log 文件 中 ,但 不 会 清空 demo.log 中 己 有 的 内 容 。 对 于 本 题 而 言 , bash demo.sh >demo.log， 
用 来 把 标准 输出 定向 到 demo.log 文件 中 ，2>&1 用 来 把 标准 错误 重 定向 到 标准 输出 。 

所 以 ， 本 题 的 答案 为 C。 

11. 答案 : C。 

分 析 : 本 题 考 察 的 是 对 bash 中 赋值 的 理解 。 
bash 中 赋值 语句 的 写法 为 :变量 名 称 = 值 (等 号 两 边 不 能 有 空格 )。 所 以 ， 选 项 C 正确 。 
所 以 ， 本 题 的 答案 为 C。 
12. 答案 : D。 
分 析 : 本 题 考 察 的 是 对 sed 命令 的 理解 。 
sed 是 一 种 在 线 编辑 器 ， 一 次 处 理 一 行内 容 ， 主 要 用 来 自动 编辑 一 个 或 多 个 文件 ， 以 简化 


|| 


对 文件 的 反复 操作 。 处 理 过 程 如 下 : 把 当前 处 理 的 行 存储 在 临时 缓冲 区 中 ， 称 为 “模式 空间 ”， 
然后 用 sed 命令 对 缓冲 区 中 的 内 容 进行 处 理 ， 处 理 完 之 后 ， 把 缓冲 区 的 内 容 送 往 屏幕 ， 接 着 
去 处 理 下 一 行 ， 这 样 不 断 地 重复 ， 直 到 文件 未 尾 ， 这 种 处 理 方式 默认 情况 下 并 没有 改变 文件 
的 内 容 。 

sed 的 使 用 方式 为 : sed [-nefr] [动作 ]， 选 项 与 参数 见 表 21。 


表 21 sed 的 选项 与 参数 


选项 参数 
本 使 用 安静 〈silent) 模式 。 在 一 般 sed 的 用 法 中 ， 所 有 来 自 STDIN 的 资料 一 般 都 会 被 列 出 到 屏幕 上 。 但 如 果 加 上 -= 


参数 后 ， 则 只 有 经 过 sed 特殊 处 理 的 那 一 行 〈 或 者 动作 ) 才 会 被 列 出 来 
直接 在 指令 列 模 式 上 进行 sed 的 动作 编辑 ， 在 多 命令 操作 的 时 候 用 得 较 多 

时 接 将 sed 的 动作 写 在 一 个 文件 内 

I: sed 的 动作 能 支持 延伸 型 正规 表示 法 的 语法 

了 直接 修改 读 取 的 文件 内 容 ， 而 不 是 输出 到 终端 


动作 : [nl1[,n2]] 动 作 行为 
nl, n2: 用 来 表示 选择 进行 动作 的 行 数 ， 例 如 ， 如 果 想 要 后 面 的 动作 在 100 一 200 行 之 间 


1 
ed 
了 
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进行 ， 则 用 100，200 动作 行为 来 表示 。 
下 面 介绍 几 个 常用 的 动作 行为 见 表 22。 


表 22 常用 的 动作 行为 


a\: 在 当前 行 后 添加 一 行 或 多 行 

Ol: 新 文本 替换 当前 行 中 的 文本 

d: 除 行 

i\: 在 当前 行 之 前 插入 文本 

p: 打印 这 一 行 

s: 个 字符 串 替 换 另 外 一 个 字符 串 

g 区 出 暂 存 缓冲 区 的 内 容 ， 将 其 复制 到 模式 绥 冲 区 


例如 ，1,20s/old/mew/g 就 是 把 1 一 20 行 中 的 old 蔡 换 成 new。 


本 题 中 ， 对 了 


[选项 A 和 选 


选项 A 和 选项 C 错误 。 


对 于 选项 B，sed VERP/p' demo.log，1 
包含 ERP 的 行 。 
青 打印 一 壳 。 所 以 ， 选 项 B 错误 。 

对 于 选项 D，sed -n YERP/p' demo.log,，-n 取消 默认 
-p 是 指 打印 行 ，demo.log 是 指定 的 文件 。 所 以 ， 选 项 D 正确 。 


默认 情况 下 ， 


所 以 ， 本 题 的 答案 为 D。 

13. 答案 : D。 

分 析 : 本 题 考 察 的 是 Linux 操作 系统 知识 。 

对 于 选项 A，.rpm 格式 的 文件 需要 用 rpm 命令 来 安装 。 所 以 ， 选 项 A 错误 。 
令 


0 
对 于 选项 B，.tar.gz 格式 的 文件 必须 首先 用 


B 错误 。 


项 C，a 和 d 分 别 是 添加 和 删除 的 意思 ， 显 然 是 错误 的 。 所 以 ， 


于 没有 采用 安静 模式 ， 因 此 ， 会 打印 demo.log 中 
sed 把 所 有 行 都 打印 到 屏幕 ， 如 果 某 行 匹配 到 模式 ， 则 把 该 行 


的 输出 ， 只 把 包含 ERP 的 行 打印 出 来 ， 


对 于 选项 C，.tar.bz2 格式 的 文件 也 需要 用 tar 命令 解压 ， 解 压 后 才能 安装 。 所 以 ， 选 项 C 


普 误 。 


对 于 选项 D，.deb 格式 的 文件 需要 用 dkpg 命令 来 安装 。 所 以 ， 选 项 D 正确 。 
所 以 ， 本 题 的 答案 为 D。 
14. 答案 : D。 

分 析 : 本 题 考 察 的 是 链表 知识 。 


链表 是 一 种 物理 存储 单元 上 非 连续 、 非 顺序 的 存储 结构 ， 数 据 元 素 的 逻辑 顺序 是 通过 链 
表 中 的 指针 链接 次 序 实现 的 。 链 表 由 一 系列 结 点 (链表 中 每 
可 以 在 运行 时 动态 生成 。 每 个 结 点 包括 


个 元 素 称 为 结 点 ) 组 成 ， 结 点 
两 个 部 分 : 一 个 是 存储 数据 元 素 的 数据 域 ， 另 一 个 是 


存储 下 一 个 结 点 地 址 的 指针 域 。 由 此 可 见 ， 可 以 通过 结 点 的 指针 域 找到 下 一 个 结 点 ， 存 储 地 


址 是 否 连 续 并 不 重要 。 所 以 ， 选 项 A、 选 项 B 及 选项 C 错误 ， 选 项 D 正确 。 
数组 与 链表 不 同 ， 对 数组 的 访问 是 通过 数组 的 下 标 来 访问 的 ， 所 以 ， 对 
也 址 必须 是 连续 的 。 


需要 注意 的 是 ， 


于 数组 而 言 ， 存 储 # 


所 以 ， 本 题 的 答案 为 D。 
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15. 答案 : C。 
分 析 : 本 题 考 察 的 是 哈 希 表 知识 。 
对 于 选项 A， 对 于 哈 希 表 而 言 ， 散 列 冲突 的 问题 需要 解决 ， 


散 列 冲突 的 现象 将 更 加 明显 ， 因 此 ,不 能 在 常数 的 时 间 找 到 特定 记录 。 所 以 ， 选 项 A 不 正确 。 
对 于 选项 B， 喻 希 表 中 的 数据 既 可 以 在 内 存 中 ， 也 可 以 被 映 冉 到 外 存 


以 ， 选 项 B 不 正确 。 
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尤其 是 当 数 据 量 大 的 时 候 ， 


P 《例如 文件 )。 所 


对 于 选项 C， 在 最 坏 的 情况 下 ， 每 个 记录 都 有 散 列 冲突 ， 在 这 种 情况 下 ， 查 找 的 效率 与 


线性 查找 的 效率 是 一 样 的 ， 时 间 复 杂 度 为 Om。 所 以 ， 选 项 C 正确 。 
A 的 数据 类 型 的 不 同 ， 需 要 
选择 不 同 的 哈 希 函数 。 哈 希 函 数 的 好 坏 对 查找 性 能 有 着 直接 的 影响 。 所 以 ， 选 项 D 不 正确 。 


对 于 选项 D， 哈 希 函 数 的 选择 跟 字 段 A 有 直接 的 关系 ， 根 据 


所 以 ， 本 题 的 答案 为 C。 

16. 答案 : C。 

分 析 : 本 题 考 察 的 是 数据 库 知 识 。 

在 数据 库 中 ， 内 连接 也 称 为 自然 连接 ， 只 有 两 个 表 相 匹配 的 


删除 与 其 他 连接 表 中 没有 匹配 行 的 所 有 行 ， 所 以 ， 内 连接 可 能 会 
语法 如 下 : 


行 才能 在 结果 集中 出 现 ， 返 


回 的 结果 集 是 两 个 表 中 所 有 相 匹 配 的 数据 ， 而 舍弃 不 匹配 的 数据 。 由 于 内 连接 是 从 结果 表 中 


造成 信息 的 丢失 。 内 连接 的 


select fieldlist from tablel [inner] join table2 on tablel.column=table2.column 
内 连接 是 保证 两 个 表 中 所 有 的 行 都 要 满足 连接 条 件 。 与 内 连接 不 同 ， 外 连接 不 仅 包 含 符 
合 连接 条 件 的 行 ， 而 且 还 包括 左 表 〈 左 外 连接 时 )、 右 表 〈 右 外 连接 时 ) 或 两 个 边 接 表 (全 外 


连接 ) 中 的 所 有 数据 行 ， 也 就 是 说 ， 只 限制 其 中 一 个 表 的 行 ， 而 不 限制 另 一 个 表 的 行 。SQL 


的 外 连接 共有 3 种 类 型 : 左 外 连接 (关键 字 为 LEFTOUTERJOIN )、 右 外 连接 〈 关 键 字 为 
RIGHTOUTERJOIN) 和 全 外 连接 (关键 字 为 FULLOUTERJOIN)。 外 连接 的 用 法 和 内 连接 一 


样 ， 只 是 将 INNERJOIN 关键 字 替 换 为 相应 的 外 连接 关键 字 即 可 。 
内 连接 只 显示 符合 连接 条 件 的 记录 ， 外 连接 除了 显示 符合 连 
左 外 连接 ， 还 显示 左 表 中 记录 。 
列 如 ， 有 两 个 学 生 表 A 和 课程 表 B， 见 表 23 和 表 24。 


接 条 件 的 记录 乡 


， 例 如 若 用 


表 23 学 生 表 A 


学 号 姓名 
0001 张 三 
0002 李 四 
0003 王 五 
表 24 课程 表 
| 
0001 数学 
0002 英语 
0003 数学 
0004 计算 机 
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对 表 A 和 表 B 进行 内 连接 后 的 结果 见 表 25 
表 25 内 连接 结果 
学 号 姓名 课程 名 
0001 张 三 数学 
0002 李 四 英语 
0003 计 浙 数学 
对 表 B 和 表 A 进行 左 外 连接 后 结果 见 表 26: 
表 26 左 外 连接 结果 
学 号 姓名 课程 名 
0001 张 三 数学 
0002 李 四 英语 
0003 下 五 数学 
0004 计算 机 


所 以 ， 本 题 的 答案 为 C。 
17. 答案 : B。 


分 析 : 本 题 考察 的 是 排序 二 又 树 知识 。 


素 的 值 ， 所 有 右 子 树 结 点 元 素 的 值 都 大 于 这 个 结 点 元 素 的 值 


由 于 
选项 B 正确 。 


所 以 ， 本 题 的 答案 为 B。 
18. 答案 : B。 
分 析 : 本 题 考察 的 是 JavaScript 隐 式 类 型 转换 知识 。 


序 遍 历 的 顺序 为 左 子 树 、 


日 


左 


排序 二 又 树 的 特点 为 : 对 于 一 个 结 点 而 言 ， 所 有 左 子 树 结 点 元 素 的 值 都 小 于 这 个 结 点 元 


生子 树 


都 是 排序 二 又 树 。 


民 和 右 子 树 ， 显 然 ， 中 序 遍 历 得 到 的 序列 是 有 序 的 。 所 以 ， 


当 不 同类 型 的 数据 参与 运算 的 时 候 ，JavaScript 会 自动 尝试 类 型 转换 ， 当 字符 串 与 数字 混 


合 运算 的 时 候 ， 字 符 会 
的 值 为 “40” 首先 会 把 a 转换 为 整 型 ， 


B 正确 。 


所 以 ， 本 题 的 答案 为 B。 
19. 答案 : C。 


分 析 : 本 题 考 察 的 是 对 CSS Sprites 技术 的 理解 。 


CSS Sprites 是 把 网 页 中 一 些 背 景 图 片 整合 到 一 张 图 


然后 再 执行 计算 ， 因 


被 隐 式 地 转换 为 数字 后 进行 运算 。 所 以 ， 当 执行 a%b 运算 时 ， 
此 ， 计 算 结 果 为 5。 所 以 ， 选 项 


I 于 a 


片 文 件 中 ， 再 利用 CSS 的 


“background-image”“background- repeat” 和 “background-position ”的 组 合 进 行 背景 定位 ， 


“background-position” 可 以 用 数字 精确 地 定位 出 背景 图 片 的 位 置 。 
当 页 面 加 载 时 ， 不 是 加 载 每 个 身 
少 HTTP 请 求 的 次 数 ， 从 而 减轻 月 


使 效果 更 流畅 ， 不 会 停顿 。 从 上 国 
项 C 而 言 ， 当 采用 CSS 图 片 精灵 对 
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图 


独 的 图 片 ， 而 是 一 次 加 载 整个 组 合 
R 务 器 的 压力 ， 同 时 缩短 巧 停 加 载 图 片 所 需要 的 时 间 延 迟 ， 
的 分 析 可 以 发 现 ， 选 项 A、 选 项 B 和 选项 DD 正确 。 对 于 选 
片 进 行 合成 时 ， 合 成 后 的 图 片 比 小 


图 片 。 这 样 能 大 大 减 


图 片 更 小 ， 


因此 ， 选 


项 C 错误 。 


所 以 ， 本 题 的 答案 为 C。 
20. 答案 : A。 
分 析 : 本 题 考 察 的 是 数据 库 知 识 。 


视图 是 由 从 数据 库 的 基本 表 中 选取 


详解 篇 


8 来 的 数据 组 成 的 逻辑 窗口 ， 不 同 于 基本 表 ， 它 是 一 


个 虚 表 ， 在 数据 库 中 ， 存 放 的 只 是 视图 的 定义 而 已 ， 而 不 存放 视图 包含 的 数据 项 ， 这 些 项 目 


仍然 存放 在 原来 的 基本 表 结构 中 。 


视图 的 作用 非常 多 ， 主 要 有 以 下 儿 点 : 首先 ， 它 可 以 简化 数据 查询 语句 ， 其 次 ， 


它 可 以 


使 用 户 能 从 多 角度 看 待 同一 数据 ， 再 次 ， 它 可 以 提高 数据 的 安全 性 ， 最 后 ， 它 提供 了 一 定 程 
度 的 风 辑 独立 性 等 


通过 引入 视图 机 制 ， 


症 繁 


大 大 提高 了 月 


昌 户 效率 与 用 户 满意 度 ， 


户 可 以 将 注意 力 集 中 在 其 关心 的 数据 上 而 非 全 部 数据 上 ， 这 样 就 


i 且 如 果 这 些 数据 来 源 于 多 个 基本 表 结 构 ， 或 者 数据 不 


仅 来 自 于 基本 表 结 构 ， 还 有 一 部 分 数据 来 源 于 其 他 视图 ， 并 且 搜 索 条 件 又 比较 复杂 时 ， 需 要 


编 


视图 可 以 将 表 与 表 之 间 的 复杂 的 操作 连接 和 搜索 条 们 


个 视图 进行 查询 即 可 ， 所 以 ， 视 图 增加 了 数据 的 安全 怕 


对 于 选项 A， 视 图 可 以 被 定义 为 多 个 表 的 连接 ， 也 可 以 


足 条 件 的 部 分 行 可 见 ， 因 此 ， 有 更 强 的 定义 功能 。 
对 于 选项 B， 视 图 有 的 操作 ， 表 都 有 ， 视 图 一 般 被 用 来 查找 而 使 


普 误 。 


写 的 查询 语句 就 会 比较 繁琐 ， 此 时 定义 视图 就 可 以 使 数据 的 查询 语句 变 得 简单 


可 行 。 定 义 


对 用 户 不 可 见 ， 月 


上 户 只 需要 简单 地 对 一 


所 以 ， 选 项 A 正确 。 


E， 但 是 它 不 能 提高 查询 的 效率 。 
被 定义 为 只 有 部 分 列 可 见 ， 或 满 


用 。 所 以 ， 选 项 B 


对 于 选项 C， 视 图 的 数据 控制 能 力 要 强 于 表 ， 视 图 可 以 被 定义 为 多 个 表 的 连接 ， 也 可 以 


同 的 权限 ， 可 以 很 灵活 地 对 数据 进行 控制 。 所 以 ， 选 项 C 错误 。 
对 于 选项 D， 
所 以 ， 本 题 的 答案 为 A。 

21. 答案 ， A。 
分 析 : 本 题 考 察 的 是 数据 库 知 识 。 


范 化 是 在 识别 数据 库 中 的 数据 元 素 、 关 系 ， 以 及 定义 所 需 的 表 和 各 表 中 的 项 


自然 也 就 错 了 。 


工作 之 后 的 


个 细 


移动 电话 )。 


2NF， 即 第 二 范式 ， 是 有 有 


有 多 个 值 ， 即 实体 ! 
就 可 能 需要 定义 一 个 新 的 实体 ， 新 的 实体 


属性 组 成 。 简 而 言 之 ,第 
组 成 的 表 (一 个 人 可 能 


范式 就 是 无 重复 的 列 。 


被 定义 为 只 有 部 分 列 可 见 ， 或 满足 条 件 的 部 分 行 可 见 ， 通 过 定义 不 同 的 存储 过 程 ， 并 授予 不 


目 这 些 初始 


化 的 过 程 。 常 见 的 范式 有 1INF、2NF、3NF、BCNEF 以 及 4NF。 以 下 将 分 别 
对 这 几 种 范式 进行 介绍 。 
INF， 即 第 一 范式 ， 是 指数 据 库 表 的 每 一 列 都 是 不 可 分 割 的 基本 数据 项 ， 同 一 列 中 不 能 
的 某 个 属性 不 能 有 多 个 值 或 者 不 能 有 重复 的 属性 。 如 果 出 现 重 复 的 属性 ， 


例如 ，! 


了 一 个 办 公 电 话 和 一 个 移动 电话 )， 这 时 将 其 
话 号 码 分 为 “办 公 电 话 ” 和 “移动 电话 ”两 个 属性 ， 即 职工 表 (职工 号 、 姓 名 、 办 公 电 话 和 


| 重复 的 属性 构成 ， 新 实体 与 原 实体 之 间 为 一 对 多 
关系 。 第 一 范式 的 模式 要 求 属性 值 不 可 再 分 裂 成 更 小 部 分 ， 即 属性 项 不 能 是 属性 组 合 或 由 组 
“职工 号 ”“ 姓 名 ”和 “电话 号 码 ” 
规范 化 为 INF 可 以 将 电 


再 


E 第 一 范式 (INF) 的 基础 上 建立 起 来 的 ， 即 满足 第 二 范式 (2NF) 
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必须 先 满足 第 一 范式 (1NF)。 


本 斌 笔试 真 题库 


AAA 


第 二 范式 (2NF) 要 求 数据 库 表 中 的 每 个 实例 或 行 必 须 可 以 被 


唯一 地 区 分 。 为 实现 区 分 通常 需要 为 表 加 上 一 个 列 ， 以 存储 各 个 实例 的 唯一 标识 。 如 果 关 系 


模式 R 为 第 一 范式 , 并 | 
二 范式 模式 。( 如 果 A 是 关系 模式 R 
是 的 非 主 属性 。) 例 妇 
键 字 (学 号 、 课 程 号 )， 但 由 于 
是 部 分 依赖 ， 而 不 是 


2 
也 


办 法 是 将 其 分 为 两 个 关系 模式 : 学 生 表 〈 学 号 、 


新 关系 通过 学 生 表 中 的 外 关键 字 课 程 号 联系 ， 在 需要 时 进行 连接 。 
3NF， 即 第 三 范式 ， 如 果 关 系 模式 R 是 第 二 范式 ， 且 每 个 非 主 属性 
的 模式 。 例 如 ， 学 生 表 〈 学 号 、 姓 名 、 课 程 号 和 成 绩 )， 其 中 ， 学 
课程 号 )， 则 存在 函数 


候选 键 ， 则 称 R 是 第 三 范式 
生 姓 名 无 重 名 ， 所 以 ， 该 表 有 两 个 候选 码 〈 学 号 、 课 程 号 ) 和 ( 姓 
课程 号 ) 一 成 绩 , 〈 姓 名、 课程 号 ) 一 成 绩 ， 唯 一 的 非 主 属性 成 


依赖 : 学 号 一 姓名 ，(〈 学 号 、 


课程 号 和 分 数 ) 和 课程 表 〔 课 程 号 、 


名 、 


绩 对 码 不 存在 部 分 依赖 ， 也 不 存在 传递 依赖 ， 所 以 ， 它 属于 第 三 范式 。 


BCNF 构建 在 第 三 范式 
赖 于 R 的 候选 键 ， 那 么 称 RR 


EE 


ES 


存在 如 下 关系 : 


(仓库 号 、 存 储 物品 号 ) 一 《管理 员 


( 管 


选 码 , 表 中 的 唯一 非 关 键 字段 为 数量 ， 


首 理 员 号 、 存 储 物品 号 ) 一 《仓库 


(仓库 号 ) 一 (管理 员 号 ) 


( 管 


分 解 为 两 个 关系 表 : 仓库 管理 表 ( 仓 库 号 、 
量 )， 这 样 的 数据 库 表 


4NF， 即 第 


工 编号 、 


管理 员 号 ) 一 (仓库 号 ) 
即 存在 关键 字段 决定 关键 字段 的 情况 ， 所 以 ， 其 不 符合 BCNF 范式 。 把 仓库 管理 
管理 员 号 ) 和 仓库 表 〈 仓 库 号 、 存 储 物品 
插入 异常 和 更 新 异常 。 
上 的 多 值 依赖 集合 。 如 果 DD ， 
范式 的 模式 。 例 如 ， 职 工 表 〈 职 
只 工 也 可 能 会 有 多 个 职工 孩子 


A 
是 符合 


四 范式 ， 


AAA 生生 


付 写 第 


BCNF 范式 
四 范式 ， 设 R 是 一 个 关系 
平凡 多 值 依赖 XY 时 ，X 必 是 R 的 超 键 ， 那 么 称 
只 工 孩子 姓名 和 职工 选修 课程 )， 在 这 个 表 
姓名 ， 同 样 ， 同 一 个 职工 也 可 能 会 有 多 个 职工 选修 课程 ， 
四 范式 。 如 果 要 符合 第 
职工 表 一 〈 职 工 编号 、 职 工 孩子 姓名 ) 和 职 
有 一 个 多 值 事实 ， 所 以 ， 


管理 员 号 和 数量 )， 满 足 一 个 管理 员 只 在 


个 仓库 了 


的 基础 上 ， 如 果 关 系 模 式 R 是 第 
为 BCNF 范式 的 模式 。 假 设 仓 库 管 理 


日 R 中 每 一 个 非 主 属性 完全 函数 依赖 于 R 的 某 个 候选 键 , 则 称 R 为 第 


的 候选 键 的 一 个 属性 ， 则 称 A 是 的 主 属性 ， 否 则 称 A 
1， 在 选课 关系 表 〈 学 号 、 课 程 号 、 成 绩 和 学 分 ) 中 ， 关 键 字 为 组 合 关 
E 主 属性 学 分 仅 依赖 于 课程 号 ， 对 关键 字 〈 学 号 、 课 程 号 ) 只 

依赖 ， 所 以 ， 此 种 方式 会 导致 数据 见 余 以 及 更 新 异常 等 问题 ， 


解决 


学 分 )， 


都 不 传递 依赖 于 及 的 


范式 ， 且 每 个 属性 都 不 传递 依 
关系 表 (仓库 号 、 存 储 物品 


[ 作 ， 一 个 仓库 可 以 存储 多 种 物品 ， 则 


、 存 储 物品 号 ) 都 是 仓库 管理 关系 表 的 候 


口 


1 


四 范式 。 


对 于 本 题 而 言 ， 这 个 关系 模式 的 候选 键 为 {X1,X2}， 因 


的 ， 消 除了 删除 
模式 ，D 是 R 
三 隐 >7< 司 


及 十 种 
hh ， 同 一 个 


了 FI 


名 党， 


四 


三 范式 的 。 但 是 , 由 于 存在 如 下 决定 关系 : 


关系 表 


号 和 数 


成 立 非 


即 这 里 存在 着 多 值 事实 ， 不 符合 第 


表 


( 职 


编号 、 


只 工 选 


为 X2 一 X4， 说 明 有 非 主 


部 分 依赖 于 候选 键 {X1,X2}， 所 以 ， 这 个 关系 模式 不 为 第 二 范式 。 
所 以 ， 本 题 的 答案 为 A。 


22. 答案 : B。 


分 析 : 本 题 考察 的 是 二 又 搜索 树 知 识 。 
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需要 将 此 表 分 为 两 个 表 ， 使 它们 只 有 一 个 多 值 事实 ， 例 如 
驳 课 程 )， 两 个 表 都 只 


属性 X4 


车 


真题 详解 篇 


二 又 查 找 树 (Binary Search Tree) 又 称 为 二 又 搜索 树 或 二 又 排序 树 ， 它 或 者 是 一 棵 空 树 ， 
或 者 是 具有 下 列 性 质 的 二 又 树 : 若 它 的 左 子 树 不 空 ， 则 左 子 树 上 所 有 结 点 的 值 均 小 于 它 的 根 
结 点 的 值 ， 若 它 的 右 子 树 不 空 ， 则 右 子 树 上 所 有 结 点 的 值 均 大 于 它 的 根 结 点 的 值 ， 它 的 左 、 
右 子 树 也 分 别 为 二 又 查找 树 。 

二 又 搜 索 树 的 优点 是 : 树 中 的 元 素 是 有 序 的 ， 对 二 又 搜索 树 的 查找 类 似 于 二 分 查找 ， 显 
然 ， 查 找 过 程 中 比较 的 次 数 越 少 ， 效 率 就 越 高 。 显 然 ， 选 项 B 正确 。 
对 于 选项 A， 二 又 搜索 树 的 好 坏 与 关键 码 的 个 数 没有 直接 关系 。 所 以 ， 选 项 A 错误 。 

对 于 选项 C 与 选项 D， 如 果 所 有 结 点 的 左 孩子 〈 右 孩子 ) 都 为 空 ， 那 么 查找 效率 跟 线性 
查找 相同 ， 时 间 复 杂 度 都 为 O(n)。 所 以 ， 选 项 C 与 选项 DD 错误 。 

所 以 ， 本 题 的 答案 为 了 B。 

二 、 多 项 选择 题 

1. 答案 B、D。 

分 析 : 本 题 考 察 的 是 对 硬 链 接 的 理解 。 

Linux 链接 分 两 种 ， 一 种 被 称 为 硬 链 接 (Hard Link)， 另 一 种 被 称 为 符号 链接 (Symbolic 

Link )。 
硬 链接 实际 上 是 为 文件 新 建 一 个 别名 ， 链 接 文件 和 原文 件 实际 上 是 同一 个 文件 ， 也 就 
是 说 ， 硬 链接 是 一 个 文件 的 一 个 或 多 个 文件 名 。 在 Linux 操作 系统 的 文件 系统 中 ， 每 个 文件 
都 会 有 一 个 编号 ， 这 个 编号 被 称 为 索引 结 点 号 〈Inode Index)。 在 Linux 操作 系统 中 ， 硬 链 
接 的 实现 方式 为 使 多 个 文件 名 指向 同一 索引 结 点 ,从 而 使 得 一 个 文件 可 以 拥有 多 个 有 效 的 路 
径 名 。 硬 链接 就 是 让 多 个 不 在 或 者 同 在 一 个 目录 下 的 文件 名 ， 同 时 能 够 修改 同一 个 文件 ， 其 
中 一 个 修改 后 , 所 有 与 其 有 硬 链 接 的 文件 都 一 起 修改 了 。 需 要 注意 的 是 ， 硬 链接 是 不 能 跨 文 
件 系统 的 。 

符号 链接 也 叫 软 链接 ， 它 非常 类 似 于 Windows 的 快捷 方式 ， 是 一 个 特殊 的 文件 。 在 符号 
链接 中 ， 文 件 实际 上 是 一 个 文本 文件 ， 其 中 包含 有 另 一 文件 的 位 置信 息 。 需 要 注意 的 是 ， 符 
号 链接 是 可 以 跨 文 件 系 统 的 。 

所 以 ， 本 题 的 答案 为 B、D。 

2. 答案 : B。 

分 析 : 本 题 考 察 的 是 对 进程 和 程序 的 理解 。 

表 27 是 程序 、 进 程 和 线程 的 定义 与 描述 。 


表 27 程序、 进程 和 线程 的 定义 与 描述 


术语 定义 与 描述 
程序 一 组 指令 的 有 序 结合 ， 是 一 个 静态 没 状态 的 文本 
进程 具有 一 定 独 立功 能 的 程序 关于 某 个 数据 集合 上 的 一 次 运行 活动 ， 是 系统 进行 资源 分 配 和 调度 的 一 个 独立 单元 


进程 的 一 个 实体 ， 是 CPU 调度 和 分 派 的 基本 单元 ， 是 比 进程 更 小 的 能 独立 运行 的 基本 单元 。 本 身 基本 上 不 拥 
线程 。 | 有 系统 资源 ， 只 拥有 一 点 在 运行 中 必 不 可 少 的 资源 〈 例 如 程序 计数 器 、 一 组 寄存 器 和 栈 ) ， 一 个 线程 可 以 创建 和 
撤销 另 一 个 线程 ， 同 一 个 进程 中 的 多 个 线程 之 间 可 以 并 发 执行 

简 而 言 之 ， 一 个 程序 至 少 有 一 个 进程 ， 一 个 进程 至 少 有 一 个 线程 。 

所 以 ， 本 题 的 答案 为 B。 


Ei 
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3. 答案 : C、D。 

分 析 : 本 题 考 察 的 是 对 正则 表达 式 的 理解 。 

*# 表 示 匹 配 0 个 或 多 个 ， 本 题 中 ， 表 达 式 A*B 表示 首先 匹配 0 个 或 多 个 字符 “A”， 然 后 
再 匹配 一 个 字符 “B”。 所 以 ， 选 项 C 和 选项 D 正确 。 

对 于 选项 A， 没 有 字符 了， 因此 ， 无 法 匹配 。 所 以 ， 选 项 A 错误 。 

对 于 选项 B， 字 符 “C” 是 无 法 匹配 的 。 所 以 ， 选 项 B 错误 。 

所 以 ， 本 题 的 答案 为 C、D。 

4. 答案 : A、B。 

分 析 : 本 题 考察 的 是 对 html 行内 元 素 的 理解 。 

块 级 元 素 会 独占 一 行 ， 默 认 情况 下 ， 其 宽度 自动 填 满 其 父 元 素 宽度 。 行 内 元 素 不 会 独占 
一 行 ， 相 邻 的 行内 元 素 会 排列 在 同一 行 里 ， 直 到 一 行 排 不 下 ， 才 会 换行 ， 其 宽度 随 元 素 的 内 
容 而 变化 。 

常见 的 行内 元 素 有 a ( 锚 点 )、abbr “缩写 )、acronym〔 首 字 )、b ( 粗 体 )、big (大 字体 )、 
br 换行 )、cite (引用 )、font (字体 设 定 )、i (斜体 )、img〔 图 片 )、input “输入 框 )、kbd〔 定 
义 键盘 文本 )、label (表格 标签 )、q〈 短 引用 )、s (中 划 线 )、samp〔 定 义 范例 计算 机 代码 )、 
select (项 目 选择 )、small (小 字体 文本 )、span〔 常 用 内 联 容器 ， 定 义 文本 内 区 块 )、strike 中 
划 线 )、strong( 粗 体 强调 )、sub (下 标 )、sup (上 标 )、textarea( 多 行文 本 输入 框 )、tt( 电 传 
文本 )、u〔 下 划 线 ) 以 及 var( 定 义 变量 )。 
常见 的 块 级 元 素 有 address〈 地 址 )、blockquote 〈 块 引用 )、center〈 居 中 对 齐 块 )、dir (日 
录 列 表 )、div( 图 层 ， 常 用 块 级 元 素 ， 也 是 css layout 的 主要 标签 )、dl (定义 列表 )、fieldset 
(form 控制 组 )、form〔 交 互 表单 )、hl〔 大 标题 )、h2〔 副 标题 )、h3 (3 级 标题 )、h4 (4 级 标 
题 )、h5 (5 级 标题 )、h6 (6 级 标题 )、hr (水 平分 隔 线 )、isindex 输入 提示 )、menu〔 菜 单 
列表 )、noframes (frames 可 选 内 容 ， 对 于 不 支持 frame 的 浏览 器 显示 此 区 块 内 容 )、noscript 
(可 选 脚本 内 容 ， 对 于 不 支持 script 的 浏览 器 显示 此 内 容 )、ol (排序 表单 )、p (段落 )、pre 〈 格 
式 化 文本 )、table( 表 格 〉 以 及 (无 序列 表 )。 

本 题 中 ， 选 项 A 与 选项 B 中 内 容 为 行内 元 素 ， 选 项 C 与 选项 D 为 块 级 元 素 : ul (无 序 
列表 )、p【〔 上 段落 )。 

所 以 ， 本 题 的 答案 为 A、B。 

5. 答案 : C。 

分 析 : 本 题 考察 的 是 对 Cookie 的 理解 。 

会 话 〈Session) 跟踪 是 Web 应 用 程序 中 常用 的 技术 ， 用 来 跟 踊 用 户 的 整个 会 话 。 常 用 的 
会 话 跟 踪 技 术 包 括 Cookie 与 Session。Cookie 指 某 些 网 站 为 了 辨别 用 户 身份 、 进 行 Session 跟 
踪 而 存储 在 用 户 本 地 终端 上 的 数据 (通常 经 过 加 密 )， 通 过 在 客户 端 记录 信息 确定 用 户 身 份 ， 
Session 通过 在 服务 器 端 记录 信息 确定 用 户 身份 。Cookie 大 小 是 有 限制 的 ， 不 同 浏览 器 的 限制 
是 不 一 样 的 ， 例 如 ，Firefox〈 火 狐 ) 对 每 个 域名 的 Cookie 限制 为 50 个 。 

本 题 中 ， 选 项 A、 选 项 B 及 选项 DD 中 描述 内 容 都 正确 ， 上 只 有 选项 C 中 描述 有 误 。 

所 以 ， 本 题 的 答案 为 C。 

6. 答案 : A、C。 


分 析 : 本 题 考察 的 是 对 数据 库 索 引 的 理解 。 


348 


真题 详解 篇 


索引 是 对 数据 库 表 中 一 列 或 多 列 的 值 进行 排序 的 一 种 结构 ， 使 用 索引 可 快速 访问 数据 库 
表 中 的 特定 信息 。 数 据 库 中 索引 可 以 分 为 两 种 类 型 : 聚 徐 索引 和 非 聚 徐 索 引 。 

聚 簇 索引 : 表 数 据 按照 索引 的 顺序 来 存储 ， 也 就 是 说 ， 索 引 项 的 顺序 与 表 中 记录 的 物理 
顺序 一 致 。 对 于 聚 簇 索 引 ， 叶 子 结 点 即 存储 了 真实 的 数据 行 ， 不 再 有 男 外 单独 的 数据 页 。 正 
因为 索引 的 数据 需 与 数据 物理 存储 的 顺序 一 致 , 在 一 张 表 上 一 次 最 多 只 能 创建 一 个 聚 艇 索引 |。 

非 聚 复 索引 ;， 表 数 据 存储 顺序 与 索引 顺序 无 关 。 对 于 非 聚 秘 索 引 ， 叶 结 点 包含 索引 字段 
值 及 指向 数据 页 、 数 据 行 的 逻辑 指针 。 为 了 提高 索引 的 性 能 ， 一 般 采 用 B 树 来 实现 。 

所 以 ， 本 题 的 答案 为 A、C。 

7. 答案 : B、D。 

分 析 : 本 题 考察 的 是 对 Web 相关 知识 点 的 理解 。 

对 于 选项 A， 静 态 网 站 是 指 全 部 由 HIML 代码 格式 页 面 组 成 的 网 站 ， 所 有 的 内 容 包含 在 
网 页 文件 中 。 静 态 网 站 中 的 网 页 是 固定 的 ， 且 每 个 网 页 都 有 固定 的 URL (Uniform Resource 
Locator， 统 一 资源 定位 符 )， 显 然 , 可 以 通过 更 改 静 态 网 页 中 的 内 容 来 更 改 网 站 的 内 容 。 所 以 ， 
选项 A 不 正确 。 

对 于 选项 B, 对 于 大 型 的 网 站 而 言 , 为 了 能 够 响应 大 量 用 户 的 访问 , 一 般 都 需要 多 个 Web 
服务 器 来 实现 ,为 了 实现 负载 均衡 , 需要 把 不 同 用 户 的 请 求 根 据 特定 的 策略 分 配 到 不 同 的 Web 
服务 器 上 来 响应 用 户 请 求 。 例 如 ，CDN (Content Delivery Network， 内 容 分 发 网 络 ) 技术 利用 
全 局 负载 均衡 技术 将 用 户 的 访问 指向 离 用 户 最 近 的 工作 正常 的 流 媒体 服务 器 上 ， 由 流 媒 体 服 
务 器 直接 响应 用 户 的 请 求 。 所 以 ， 选 项 B 正确 。 
对 于 选项 C，127.0.0.1 与 localhost 是 等 价 的 ， 可 以 用 来 访问 本 地 站 点 。 所 以 ， 选 项 C 不 
正确 。 

对 于 选项 D， 这 些 都 是 属于 Web 站 点 入 侵 方 式 。 所 以 ， 选 项 D 正确 。 

所 以 ， 本 题 的 答案 为 B、D。 

三 、 填 空 题 

1. 答案 : 5。 

这 5 种 形态 如 图 38 所 示 。 


a 


图 38 3 个 结 点 的 二 叉 树 形态 


2. 答案 : 12。 

如 果 要 使 得 二 又 树 的 高 度 最 低 ， 那 么 就 需要 把 二 又 树 每 一 层 都 排 满 ， 即 排 成 一 个 完全 二 
叉 树 ， 高 度 为 k 的 完全 二 又 树 最 多 有 2^k-1 个 结 点 。 当 k=11 时 ，24k- 1=2047<4000， 当 k=12 
时 , 2^k- 1=4095>4000。 因此 , 树 的 最 低 高 度 为 12, 且 最 后 一 层 结 点 的 个 数 为 4000-2017=1983。 

3. 答案 : -x+ABC*-DE+FG。 

前 绥 表 达 式 ， 也 称 为 “波兰 式 ” 指 的 是 不 含 括号 的 算术 表达 式 ， 而 且 它 是 将 运算 符 写 在 
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前 面 ， 操 作 数 写 在 后 面 的 表达 式 ， 例 如 ， 前 绥 表 达 式 - 1 + 23， 它 等 价 于 算术 表达 式 1-(2+3)。 

根据 以 上 分 析 可 知 ， 本 题 的 表达 式 前 级 表达 式 为 -x+ABC*-DE+FG。 

四 、 问 答题 

1. 答案 : 本 题 考察 的 是 系统 设计 知识 。 
于 所 有 数据 都 是 按照 时 间 顺 序 排列 的 ， 也 就 是 说 ， 所 有 玩家 的 数据 是 保存 在 一 块 的 ， 
因此 ， 需 要 在 对 数据 进行 壳 历 的 过 程 中 ， 首 先 把 每 个 玩家 的 数据 统计 出 来 ， 然 后 基于 这 个 统 
计 结 果 可 以 非常 容易 地 进行 其 他 统计 。 

主要 思路 如 下 : 
首先 ， 定义 如 下 数据 结构 来 记录 每 个 玩家 的 信息 ， 采 用 HashMap 的 key-value 键 - 值 对 ) 
方式 。 


key: 
char[16] ip // 通 过 了 全 来 区 分 不 同 的 玩家 
value: 
struct 
{ 
minScore int, /玩家 最 小 的 积 4 
maxScore int， /玩家 最 大 积分 
last_time int, /玩家 上 次 在 线 时 间 〈 把 日 期 类 型 转换 为 int) 
continueTime int, // 玩 家 当前 登录 在 线 时 长 
maxContinueTime int, /玩家 最 长 在 线 时 长 
} 


上 述 结构 中 ， 存 储 每 个 玩家 信息 占用 的 内 存 空间 为 (16+4+4+4+4+4) =36B。 而 考虑 到 玩 
家 个 数 为 百 万 左右 ， 假 设 玩家 数 为 一 百 万 整 ， 那 么 ， 此 时 总 共 占 用 内 存 空间 为 36B* 
10^7=36MB。 

有 了 上 述 结构 定义 ， 解 题 的 主要 思路 如 下 : 首先 遍历 所 有 数据 ， 对 于 遍历 到 的 每 一 条 数 
据 ， 根 据 其 卫 信息 找到 这 个 玩家 在 map 表 中 的 记录 信息 ， 然 后 更 新 这 个 数据 结构 中 的 值 。 对 
于 积分 和 上 次 在 线 时 间 值 的 更 新 是 很 显然 的 。 由 于 一 个 玩家 在 一 天 之 内 的 时 间 里 可 能 会 登录 
多 次 ， 因 此 ， 在 数据 结构 中 ， 定 义 了 continueTime 来 记录 玩家 本 次 登录 的 在 线 时 间 ， 一 旦 发 
现 玩家 登录 时 间 超 过 Smin 以 上 ， 则 可 以 更 新 MaxContinueTime=max{MaxContinueTime， 
continueTime } ， 然 后 再 把 continueTime 清 0。 

通过 一 次 遍历 后 ， 就 得 到 了 所 有 玩家 的 统计 信息 。 具 体 过 程 如 下 : 

1) 当 需 要 统计 在 线 时 长 最 长 的 10 个 玩家 时 ， 可 以 建立 一 个 大 小 为 10 的 小 顶 堆 ( 堆 中 存 
放 一 个 数据 结构 ， 这 个 数据 结构 中 保存 玩家 IP 和 玩家 最 长 在 线 时 长 maxContinueTime )。 裔 历 
map 表 ， 首 先 把 前 10 个 玩家 的 信息 存 入 到 小 顶 堆 中 ， 然 后 过 历 剩 余 玩 家 的 信息 。 每 当 遍 历 到 
的 maxContinueTime 大 于 堆 顶 数据 元 素 时 ， 则 替换 推 顶 的 数据 元 素 ， 然 后 把 堆 调整 为 小 顶 堆 。 
通过 一 次 遍历 后 ， 堆 中 记录 的 玩家 就 是 在 线 时 间 最 长 的 玩家 。 

2) 定义 一 个 变量 inactiveCount 用 来 记录 不 活跃 玩家 的 个 数 。 在 步骤 1) 中 遍历 玩家 信息 
的 时 候 ， 如 果 玩 家 的 minScore==maxScore， 则 执行 inactiveCount++， 因 此 ， 可 以 很 容易 求 
出 不 活跃 用 户 的 个 数 。 总 用 户 个 数 就 是 map 的 大 小 。 由 此 就 可 以 求 出 不 活跃 用 户 的 百分比 。 


2. 答案 : 参见 真题 11 中 简 答 题 4。 
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你 是 一 名 程序 猿 / 媛 吗 ? 

你 还 在 为 找 不 到 对 象 而 苦恼 吗 ? 

你 还 在 被 家 人 催促 得 烦 不 可 奈 吗 ? 

你 还 人 在 整 日 面 对 电脑 忙于 事业 无 心 婚恋 吗 ? 
约 猿 吧 ， 程 序 猿 / 媛 可 以 信赖 的 脱 单 家 园 。 

在 这 里 ， 你 可 以 认识 各 类 靠 谱 的 婚恋 对 象 。 
在 这 里 ， 你 可 以 学 习 各 种 恋爱 技巧 与 经 验 。 
在 这 里 ， 你 可 以 获得 情感 专家 一 对 一 的 解 惑 。 
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